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Vorwort 


Das Wegweiser-Buch weist Wege zum erfolgreichen Einsatz des Commo- 
dore 64. 


Das Wegweiser-Buch vermittelt aktuelles Grundlagenwissen zur Datenver- 
arbeitung bzw. Informatik: 


— Was ist Hardware, Software und Firmware? 

— Was sind Großcomputer und Mikrocomputer? 

— Was sind Datenstrukturen und Programmstrukturen? 
— Was sind Betriebssysteme und Anwenderprogramme? 
— Was heißt ‚fertige Programm-Pakete einsetzen’? 

— Was beinhaltet das eigene Programmieren? 


Nach der Lektüre dieses Abschnitts sind Sie in der Lage, den Commodore 64 
in den Gesamtrahmen des Gebiets „Datenverarbeitung/Informatik’’ einzu- 
ordnen. 


Das Wegweiser-Buch gibt eine erste Bedienungsanleitung: 


— Wie bediene ich Tastatur, Bildschirm, Floppy bzw. Disketteneinheit und 
Drucker des Commodore 64? 

— Wie erstelle ich mein erstes Programm in der Programmiersprache BASIC 
2.0? 

— Welche Befehle umfaßt BASIC 2.0 (zu jedem Befehl wird ein Beispiel an- 
gegeben)? 

— Welche Möglichkeiten bieten die drei Sprachversionen BASIC 2.0, BASIC 
4.0 und SIMON’s BASIC? 

— Laufen die Programme des Commodore 64 auf anderen Mikrocomputern 
von Commodore? 


Nach dem Durcharbeiten dieses Abschnitts können Sie Ihren Commodore 64 
bedienen, Programme laufen lassen und einfache BASIC-Programme selbst 
erstellen und speichern. 


Das Wegweiser-Buch enthält einen kompletten Programmierkurs mit folgen- 
den grundlegenden BASIC-Anwendungen: 


— Programme mit den wichtigen Ablaufstrukturen (Folge-, Auswahl-, Wie- 
derholungs- und Unterprogrammstrukturen). 

— Verarbeitung von Text, Ein-/Ausgabe und Tabellen. 

— Maschinennahe Programmierung (... Bit für Bit). 

— Suchen, Sortieren, Mischen und Gruppieren von Daten. 

— Sequentielle Datei und Direktzugriff-Datei mit den Sprachen BASIC 2.0 
und BASIC 4.0. 


VI Vorwort 


— Normale Grafik mit der Standardsprache BASIC 2.0. 

— HIRES-Grafik und Sprite-Grafik mit SIMON’s BASIC. 

— Kontrollanweisungen für die Programmstrukturen mit SIMON’s BASIC. 
— Programmierung von Musik mit SIMON’s BASIC. 


Nach Lektüre dieses Abschnitts können Sie die wichtigsten BASIC-Sprach- 
möglichkeiten des Commodore 64 nutzen. 


Das Wegweiser-Buch soll die von Commodore gelieferten System-Handbücher 
keinesfalls ersetzen, sondern ergänzen: 

In den Handbüchern werden Programmiersprachen (z.B. BASIC 2.0 im Com- 
modore 64 MicroComputer Handbuch), das DOS-Betriebssystem (z.B. 
VC 1541 Floppy Disk Bedienungs-Handbuch), technische Eigenschaften 
(Hardware), spezielle Geräte oder Software beschrieben. Das Wegweiser- 
Buch hingegen beschreibt die Grundlagen der Datenverarbeitung, um sie an 
zahlreichen Anwendungsmöglichkeiten für den Commodore 64 zu demon- 
strieren und zu veranschaulichen. 


Im Wegweiser-Buch sind 78 Programm-Beispiele als Codierung in BASIC 
(LIST) und als Ausführung (RUN) wiedergegeben und ausführlich erklärt. 


Die Abschnitte 2 und 3 des Wegweiser-Buches bauen aufeinander auf und 
sollten in dieser Abfolge gelesen werden. Abschnitt 1 hingegen kann parallel 
dazu bearbeitet werden. 








Abschnitt 2: 
Einstieg in 

die BASIC-Programmierung 
des Commodore 64 













Abschnitt 1: 
Computer 
allgemein 






Abschnitt 3: 
Programmierkurs mit 

BASIC 2.0 (Standard) sowie 
BASIC 4.0 und SIMON’s BASIC 






Für schnelle und eilige Commodore 64-Besitzer: Das Wegweiser-Buch läßt 
sich auch als Nachschlagewerk benutzen. Aus diesem Grund sind Inhalts- 
und Sachwortverzeichnis sehr detailliert gegliedert. 


Heidelberg, Februar 1984 Ekkehard Kaier 
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2 1 Computer allgemein 


1.1 Computer = Hardware + Software + Firmware 


1.1.1 Überblick 


Jeder Computer besteht aus Hardware (harter Ware), aus Soft- 
ware (weicher Ware) und aus Firmware (fester Ware). Dies gilt 
für Mikro- und Personalcomputer ebenso wie für Großcomputer. 


Die Hardware umfaßt alles das, was man anfassen kann: 
Geräte einerseits und Datenträger andererseits. Das wichtigste 
Gerät ist die Zentraleinheit bzw. CPU (für Central Processing 
Unit), mit der periphere Einheiten als Randeinheiten verbunden 
sind; so z.B. eine Tastatur zur Eingabe der Daten von Hand, 
ein Drucker zur Ausgabe der Resultate schwarz auf weiß und ei- 
ne Disketteneinheit zur langfristigen Speicherung von Daten 
auf einer Diskette als Datenträger außerhalb der CPU. 


Hardware 
Geräte, Einheiten: Datenträger: 


Zentraleinheit Periphere Einheiten z.B. Diskette, Kassette, 
bzw. CPU wie Disketteneinheit, Magnetplatte, Magnet- 
Tastatur, Drucker band, Winchesterplatte 


Die Hardware als harte Ware kann man anfassen 


Die Soft war e als zweite Komponente des Computers kann 
man im Gegensatz zur Hardware nicht anfassen. Software bedeu- 
tet soviel wie Information; sie umfaßt die Daten und auch die 
Programme als Vorschriften zur Verarbeitung dieser Daten. Ist 
die Hardware als festverdrahtete Elektronik des Computers fest 
und vom Benutzer nicht (ohne weiteres) änderbar, dann gilt für 
die Software genau das Gegenteil: Jeder Benutzer kann Programm 
wie Daten verändern, austauschen, ergänzen und auch zerstören. 


Software 
Daten: PıE.Q. Gramm: 
Objekte der Geordnete Folge 
Datenverarbeitung von Anweisungen 
(was wird verarbeitet?) (w ie ist zu verarbeiten?) 


Die Software als weiche Ware kann man nicht anfassen 


Die Firmware als dritte Komponente des Computers kann 
man der Hardware oder der Software zuordnen. Sie ist deshalb 
wie ein 'Zwitter' halb Hardware und halb Software. So ist z.B. 
das Rechenprogramm jedes Taschenrechners in einem speziellen 
Speicher ROM (Read Only Memory als Nur-Lese-Speicher) enthal- 
ten. Der Benutzer kann dieses Programm zwar laufen lassen und 
Information entnehmen und lesen (read), nicht jedoch abändern. 
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Für den Benutzer ist es wie Hardware fest. Für den Hersteller 
des ROMs hingegen stellt es sich wie Software veränderbar dar, 
da er den Speicher ROM ja programmieren kann und muß. 

Ein anderes Beispiel: Für viele Mikrocomputer werden Module 
mit fest im ROM gespeicherten Programmen bis zu 30.000 Zeichen 
angeboten; der Anwender steckt ein Modul in den Eingabeschacht 
seines Computers und befindet sich sogleich im Programm. Er 
kann dieses Programm als Firmware zwar laufen lassen bzw. aus- 
führen, nicht aber umprogrammieren und verändern. 

Mit der Mikrotechnologie, mit dem Chip und dem IC (Integrated 
Circuit für Integrierter Schaltkreis) hat die Firmware immer 
mehr an Bedeutung gewonnen. 


Die Hardware (fest verdrahtete Elektronik), die Software (frei 
änderbare Daten und Programme) und die Firmware (hart für den 
Benutzer und weich für den Hersteller) stellen die drei 
grundlegenden Komponenten jedes Computers dar. 
Darüberhinaus gibt es weitere ....ware: so die Orgware (Or- 
ganisation von Aufbau und Ablauf), die Menware (Personen), 
die Brainware (geistige Leistungen) und die Teachware (Lehren 

und Lernen). 


1.1.2 Kosten für die Computerleistung 


Leistung bedeutet Arbeit pro Zeiteinheit. Bestand die Arbeit 
des Computers früher im Rechnen, also im Umgang mit Zahlen 
(Computer heißt wörtlich Rechner), so wird sie heute ergänzt 
durch das Verarbeiten von Text allgemein. Die Zeiten werden 
immer kürzer: so arbeiten Computer heute 200mal schneller als 
vor 25 Jahren (Nanosekundenbereich, 1-milliardstel Sekunde). 


Betrachtet man die Entwicklung der Computerkosten, so ist ein 
zunehmendes Absinken der Kosten für die Hardware gegenüber 
den Kosten für die Software festzustellen. Zwei Gründe dafür: 
Einerseits verbilligt sich die Hardware immer mehr, sei es 
durch die Massenproduktion, sei es durch Fortschritte in der 
Mikrotechnologie. Bei entsprechender Entwicklung anderer In- 
dustriezweige dürfte ein VW-Käfer nicht mehr als 50 DM kosten 
und eine Boeing 767 nicht mehr als 1500 DM. 

Andererseits verteuert sich die Software mehr und mehr,sei es 
durch die Personalkostenintensität (Gehälter für Programment- 
wicklung, -pflege u. -wartung), sei es durch das immer höhere 
Anspruchsniveau (Erfolgsrechnung heute bereits allwöchentlich 
und früher nur einmal im Jahr zum Jahresabschluß). 

Man spricht schon von einer Kostenrelation von '20% für Hard- 
ware' gegenüber '80% für Software'. 


1.1.3 Geschichtliche Entwicklung des Computers 


Erst 1941 stellte der deutsche Ingenieur Konrad Zuse erstmals 
einen richtigen Computer vor und 1952 wurde erstmals ein Com- 
puter an ein pivates Wirtschaftsunternehmen in der BRD ausge- 
liefert. In den 60er Jahren begann die Zeit der Großcomputer 
und damit der System-Familien wie IBM/360 oder Siemens 4004. 
Die 70er Jahre wurden geprägt von der Mikrotechnologie und 
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damit vom Mikrocomputer: die Hardware wurde immer kompakter, 

schneller und preiswerter. 

Zu Beginn der 80er Jahre hat man sich an den Preisverfall der 

Hardware gewöhnt. Wen wundert es noch, daß Hardware-Preise im 

Jahr um 25% - 40% sinken? Das Interesse verlagert sich mehr 

und mehr auf die Software: Die Qualität der Programme wird 

zum entscheidenden Problem der heutigen Datenverarbeitung. 

Und in den 90er Jahren ....? Längst wird nicht mehr gelächelt 

über "intelligente" Computer,die ähnlich dem menschlichen Ge- 

hirn selbständig Probleme lösen. Die "künstliche Intelligenz" 

(abgekürzt KI) ist vor allem in Japan und den USA auf dem Vor- 
marsch. Ein japanischer Anbieter hat bereits angekündigt, bis 
1992 das erste marktreife Produkt herauszubringen. 


1.2 Hardware = Geräte + Datenträger 


1.2.1 Hardware im Überblick 
1.2.1.1 Fünf Arten peripherer Geräte bzw. Einheiten 


Um die Zentraleinheit bzw. CPU herum können bis zu fünf ver- 
verschiedene periphere Einheiten gruppiert sein: 





Eine Einheit im Zentrum (= CPU) und mehrere periphere 
Einheiten um diese CPU herum (= Peripherie) 
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Die reinen Eingabegerät e dienen ausschließlich 
der Eingabe von Information (Daten wie Programme) in die CPU. 
zu unterscheiden ist dabei die Direkteingabe von Hand (Tasta- 
tur) oder die Eingabe über einen Datenträger (z.B. über Scheck 
mittels Klarschriftbelegleser). 

Die reinen Ausgabege rät e geben Information von 
der CPU aus z.B. auf den Bildschirm, auf das Endlospapier vom 
Drucker, auf Mikrofilm (COM für Computer Output on Microfilm). 
film) oder auf Lochkarte. 

Die Dialoggeräte übernehmen zwei Aufgaben: die 
Eingabe (in die CPU hinein) wie auch die Ausgabe (aus der CPU 
heraus). Das Bildschirmgerät bzw. Datensichtgerät besteht nur 
aus Tastatur und Bildschirm, es ist das einfachste Terminal. 
Terminal heißt soviel wie Datenendstation, Endpunkt des Benut- 
zers zum Computer oder "Benutzerschnittstelle" und bezeichnet 
das Zugangsmedium des Benutzers zur CPU. Der Zugang kann dabei 
die Eingabe, die Ausgabe oder beides umfassen; er kann mecha- 
nisch, visuell, manuell und akustisch erfolgen. Ein Terminal 
umfaßt danach eine oder mehrere periphere Einheiten mit unter- 
schiedlichen Datenträgern. 

Die Externen Spe ich e r übernehmen zusätzlich 
zur Ein- und Ausgabe von Information auch deren Speicherung. 
während der Hauptspeicher als interner Speicher der CPU Infor- 
mation nur kurzfristig zur Verarbeitungszeit aufnimmt, so die- 
nen die externen Speicher der langfristigen Aufbewahrung von 
Daten und Programmen sowie der Datensicherung (Back-Up). 


Eingabegeräte, Ausgabegeräte, Dialoggeräte u. Externe Speicher 
zählen zur On - line - Peripherie, weil die 
Verbindung zur CPU on-line ist, d.h. eine direkte Kabelverbin- 
dung die Übertragung von Information ermöglicht. Im Gegensatz 
dazu tritt bei der Off-line-Peripherie an die Stelle der Über- 
tragung der Transport von Daten (samt Datenträgern), da keine 
direkte Verbindung zwischen dem peripheren Gerät und der CPU 
besteht. 


Datenerfassung heißt, Information computerlesbar 
machen. Bei Off-line-Erfassungsgeräten besteht zum Zeitpunkt 
der Datenerfassung keine direkte Verbindung zur CPU: die Daten 
werden auf einem im Erfassungsgerät mitlaufenden Datenträger 
gespeichert. Geschieht die Erfassung hingegen on-line, dann 
ist die Erfassung gleichbedeutend mit der Eingabe. 


1.2.1.2 Drei Gruppen von Datenträgern 


Nach den Geräten der Hardware (CPU, Peripherie) kommen wir nun 
zuden Datenträgern; diese müßten eigentlich In- 
formationsträger heißen, da sie nicht nur Daten speichern bzw. 
tragen, sondern auch Programme. 

Man unterscheidet gelochte, magnetische und optische Datenträ- 
ger - je nachdem, ob die Information durch Lochungen, magneti- 
sierte Punkte oder Lichtmarkierungen (hell/dunkel, Laser) dar- 
gestellt wird. 
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Dastreinsernare 


5 


gelochte magnetische optische 
Datenträger: Datenträger: Datenträger: 
Lochkarte, Magnetplatte, Markierungsbeleg, 
Lochstreifen Plattenstapel, Klarschriftbeleg, 
Diskette, Magnetschriftbeleg, 
Magnetband, Balkencode-Beleg, 
Kassette, 
Magnetblasen- Optische Platte 
speicher 


Datenträger zur Aufbewahrung von Daten und Programmen 


Die Lochkarte und der vom Fernschreiber übernommene Lochstrei- 
fen werden zunehmend durch magnetische Datenträger ersetzt. 


Die Magnetplatte als Wechselplat te (in Platten- 
einheit auswechselbar) hat meistens 37 cm Durchmesser. Beim 
Magnetplattenstapel sind z.B. 6 solcher Einzelplatten zu einem 
Stapel fest übereinander montiert mit einer Speicherkapazität 
bis 300.000.000 Zeichen (=150.000 DIN A4-Seiten). Die Diskette 
bzw. Floppy Disk als verkleinerte Form der Magnetplatte wird 
als Wechselplatte zur einseitigen oder auch zweiseitigen Spei- 
cherung bei einfacher oder doppelter (2D) Aufzeichnungsdichte 
abgeboten. Derzeit sind drei Disketten-Größen verbreitet: Die 
Maxi-Diskette mit 8" = ca. 20 cm, die Mini-Diskette mit 5.25" 
= ca. 13 cm und die Mikro-Diskette mit 3.5" = ca. 9 cm Durch- 
messer. Disketten erreichen Kapazitäten von 1.000.000 Zeichen 
(=500 DIN A4-Seiten) und mehr. 


Die Winchester-Platte ist als Festplatte fest mit 
dem Gerät verbunden und somit nicht auswechselbar. Als Kunst- 
stoffplatte ist sie in den Größen 14", 8" und 5.25" im Handel. 
Aufgrund der hohen Umdrehungszahl (mehrere 1000 mal/min gegen- 
über 360 mal/min bei der Diskette) wird eine große Zugriffsge- 
schwindigkeit wie auch Kapazität erreicht: über 50.000.000 
Zeichen/Platte sind möglich (=25.000 DIN A4-Seiten). 


Das Magnetband als d e r typische Massendatenspeicher (1,27 cm 
breit und 730 m lang) kann bis ca. 35.000.000 Zeichen (=17.500 
DIN A4-Seiten) aufnehmen. In seiner verkleinerten Form als Da- 
tenkassette werden ca. 300.000 Zeichen (=150 DIN A4-Seiten) 
erreicht; erhältlich ist die Normalkassette, die 1/4-Zoll-Kas- 
sette und die 1/8-Zoll-Kassette. 


Der Magnetblasenspeicher (Bubble Memory) arbeitet ohne mecha- 
nische Teile und wird den herkömmlichen Medien (Band, Platte) 
demnächst Konkurrenz machen. 


Zu den optischen Datenträgern, die der direkten Beleglesung 
dienen: Beim Markierungsbeleg (Erhebungen, TÜV, Bestellungen) 
werden Ja/Nein-Markierungen mit Bleistift ausgefüllt und vom 
Belegleser optisch eingelesen. 


Beim Klarschriftbeleg (Scheck, Zahlkarte) wird optisches Zei- 
chen-Erkennen (OCR für Optical Character Recognition) dadurch 
erreicht, daß speziell für die DV genormte OCR-Schriften ver- 
wendet werden wie OCR-A, OCR-B und IBM-407. 

Beim Magnetschriftbeleg (Post-Briefverteilung) werden einzelne 
Zeichen mit senkrechten Balken aus magnetisierter Farbe darge- 
stellt: jeweils 7 Balken bei der CMC-7-Schrift, Dick-Dünn-Ab- 
weichungen bei der E-13-B-Schrift des US-Banksystens. 

Seit der Vereinbarung des Europa-Artikel-Nummern-Codes (EAN- 
Code) im Jahre 1977 findet sich dieser Balkencode -auch Bar- 
oder Strichcode genannt- zunehmend auf Warenpackungen. Durch 
Abtasten mit einem Lesegerät bzw. Scanner (to scan = abtasten) 
wird die Artikelnummer entschlüsselt. 


Bei der optischen Platte tritt an die Stelle des Schreib-/Le- 
sekopfs der herkömmlichen Magnetplatteneinheiten der Laser- 
lichtstrahl. Dabei sind die gespeicherten Daten nicht mehr än- 
derbar; aufgrund des niedrigen Preises wird einfach auf eine 
zweite optische Platte kopiert. Die Kapazität liegt bei über 
100.000.000 Zeichen (=50.000 DIN A4-Seiten), ist also äußerst 
hoch. 


1.2.2 Verarbeitung von Information in der CPU 
1.2.2.1 Analogie der Datenverarbeitung bei Mensch und Computer 
Die Datenverarbeitung beim Computer vollzieht sich analog zur 


Datenverarbeitung beim Menschen: die CPU als "Gehirn des Conm- 
puters' ist analog zum menschlichen Gehirn aufgebaut. 


Mensch: Computer; 


GEHIRN a 3) 


Leitwerk 
Intelligenz Prozessor 


Gedächtnis Hauptspeicher 


Verhalten | | Programm | 





Grundmodelle der Datenverarbeitung bei Mensch und Computer 


Der Eingabe (E) beim Menschen (Datenaufnahme über Auge, Ohr, 
Nase) entspricht die computerlesbare Eingabe von der Tastatur, 
Die Intelligenz des Computers wird durch einen Prozessor ver- 
körpert, der die arithmetischen und logischen Grundoperationen 
durchführt (ALU für Arithmetic Logical Unit) sowie das Gesamt- 
system steuert (Steuer- bzw. Leitwerk). 
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Neben der Intelligenz (Prozessor) als steuerndem bzw. aktivem 
Teil des Gehirns nun zum Gedächtnis (Hauptspeicher) als auf- 
nehmendem bzw. passivem Teil: den menschlichen Verhaltensab- 
läufen - sicher äußerst vage - vergleichbar sind die Computer- 
programme als Anweisungsfolgen " w i e zu verarbeiten ist" , 
während die gespeicherten Daten angeben " wa s verarbeitet 
wird". 

Die Ausgabe (A) bzw. Datenwiedergabe (z.B. durch Sprechen und 
handschriftlich) erfolgt beim Computer in computerlesbarer 
Form (z.B. Ausgabe der Lohndaten auf Diskette) und/oder men- 
schenlesbarer Form (z.B. am Bildschirm oder Drucker). 


Mensch wie Computer sind datenverarbeitende Systeme, die durch 
die 3-Schritt-Folge "Eingabe -> Verarbeitung -> Ausgabe" (kurz 
EVA-Prinzip genannt) gekennzeichnet werden können. 


Als CPU dient beim Personalcomputer bzw. Mikrocomputer ein IC 
auf einem ca. 0.5 cm langen Silicium-Chip. Ein weiterer IC ist 
für den Hauptspeicher (auch Arbeitsspeicher genannt) vorgese- 
hen. Öffnet man den Computer, dann wird man diese und weitere 
Chips sehen, die auf Kunststoffplatinen angeordnet und über 
aufgedruckte Leiterbahnen miteinander verbunden sind. 


Für Skeptiker: Die hier dargestellte Analogie der Datenverar- 
beitung bei Mensch und Computer bedeutet nicht, daß Computer 
künstliche Menschen sind, sondern daß sie ihm im Grundaufbau 
nachgebaut sind. Das einzig Menschliche an Computern ist, daß 
sie vom Menschen konstruiert sind. Sonst sind Computer dumm; 
sie können nur so arbeiten, wie ihnen durch die Programme vor- 
geschrieben wurde. Diese Programme haben zudem etwas äußerst 
unmenschliches an sich: sie beinhalten vornehmlich sich oft 
wiederholende, routinemäßig ablaufende und stupid geistestö- 
tende Tätigkeiten, die von Computern aber sehr schnell, exakt 
und beliebig oft ausgeführt werden können. 


1.2.2.2 Computer als speicherprogrammierte Anlage 


Früher -und das ist erst etwa 30 Jahre her- war das jeweilige 
Programm als Hardware festverdrahtet: so konnte der Buchungs- 
automat nur die Buchhaltung besorgen, der Fakturiertautomat 
nur Rechungen schreiben und der Sortierautomat nichts als nur 
sortieren. Für jede neue Aufgabe mußte ein neuer Automat ange- 
schafft werden. 

Diesem sicher unwirtschaftlichen Hardware-Prinzip machte John 
von Neumann (1903-1957) mit der folgenden ohne Zweifel revolu- 
tionärsten Idee in der Geschichte der EDV ein Ende:danach ent- 
hielt der Hauptspeicher nicht nur die zu verarbeitenden Daten, 
sondern auch das Programm. Da neben den Daten (was wird 
verarbeitet) auch das Programm ( w i e ist zu verarbeiten) 
geändert und ausgetauscht werden konnte, wurde ein und dersel- 
be Computer (Hardware bzw. Gerät unverändert) zum universellen 
Problemlösungsinstrument (Software bzw. Programm änderbar). 
Die oben angeführten Aufgaben der Buchhaltung, Fakturierung 
wie Sortierung ließen sich von e ine m Computer mit den 
entsprechenden Programmen lösen. 

Das Prinzip der Speicherprogrammierung 
hatte das Hardware-Prinzip abgelöst: e i n Computer mit vielen 
austauschbaren Programmen dient heute v ie 1 en Aufgaben. 
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1.2.2.3 Computerrechnen im Dual-System Bit für Bit 


Das Rechnen vollzieht sich in der ALU als Bestandteil der CPU. 
Wie ist dies möglich, wo der Computer doch nur Binärzeichen 
(binär bedeutet zweiwertig) mit den zwei möglichen Zuständen 
0 (kein Strom) und 1 (Strom) unterscheiden kann? Er rechnet 
im 2er-System bzw. Dual-System und nicht wie wir Menschen im 
10er-System bzw. Dezimal-System. 

Addieren wir 5+9 = 14, so erfolgt das berühmte "1 im Köpfchen" 
bei 10, da wir im 10-er System denken. Der Computer führt den 
Übertrag nicht bei 10 durch, sondern bei 2, da er gelernt hat, 
im 2er-System zu funktionieren. Woher aber weiß er, wie groß 
Stellenergebnis und -übertrag sind? Er weiß es durch folgenden 
Trick: Die Addition ist auf die logischen Grundoperationen 
"logisch UND" und "logisch ODER" zurückführbar, und diese Ope- 
rationen lassen sich als Schalter in der ALU darstellen. Damit 
benötigt ein Computer im Grunde nur so wenige Schalter, wie 
logische Operationen darzustellen sind. 





5 + 9 dezimal: 5 + 9 dual: duale Addition 
allgemein: 
3 2 1 0 3 2 1 0 
1077710 27T. 10 2 2 2 2 0 +0 = O behalte 0 
0 + 1= 1 behalte 0 
0 0 0 5 0 1 0 1 1 +0 = 1 behalte O0 
0 0 Ü 9 1 0 0) 1 1 + 1 = 0 behalte ] 
0 0 1 4 1 1 1 0 
|logisch 
1#8 + 1*%4 + 1#%2 + 0%1 = 14 ODER 
1%10 + 4*#1 - 14 
also; dual 1110 gleich dezimal 14 logisch UND 





Dezimale Addition 5+9 (links), duale Addition 5+9 (rechts) 


Das Binärzeichen wird als Bit (Binary Digit) abgekürzt. Die 
4-Bit-Folge 1110 als Bitmuster bezeichnet die Dezimalzahl 14. 


1.2.3 Speicherung von Information intern im Hauptspeicher 


Information (Daten, Programme) setzt sich zusammen aus Zeichen 
wie Buchstaben, Ziffern und Sonderzeichen. Da der Computer nur 
ein Bit mit den beiden Werten O0 und 1 unterscheiden kann, muß 
jedes Zeichen als Bitmuster gespeichert werden, z.B. der Buch- 
stabe K durch das Bitmuster 01001011 als 8-Bit-Folge. Auf den 
Datenträgern werden Bits meist durch magnetisierte Punkte dar- 
gestellt. Im Hauptspeicher dagegen werden Bits durch Schalter 
dargestellt, die auf 'aus' für 0 oder auf 'ein' für 1 stehen 
können; der Hauptspeicher als elektronischer Speicher besteht 
aus ICs, deren Schalterstellungen den Bitwerten entsprechen. 
Auf die externe Speicherung auf Datenträgern geht Abschnitt 
1.2.4 ein; dieser Abschnitt wendet sich der internen Speicher- 
ung im Hauptspeicher (auch Arbeitsspeicher genannt) zu. 
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1.2.3.1 Informationsdarstellung im ASCII und EBCDI-Code 


Im Hauptspeicher wird Information vorherrschend im ASCII (für 
American Standard Code for Information Interchange) zu jeweils 
sieben Bits/Zeichen gespeichert. Jedes ASCII-Zeichen wird so- 
mit als Siebenbitmuster dargestellt. Im ASCII werden dadurch 
128 (2 hoch 7) Möglichkeiten computerlesbar erfaßt. 

Unabhängig vom Code faßt man jeweils 8 Bits zu einer Einheit 
zusammen, die man By t e nennt. Beim ASCII als 7-Bit-Code 
ist das 8. Bit eines Byte prinzipiell frei; je nach Anwwendung 
wird es verschieden behandelt (z.B. stets 0 oder zur Aufnahme 
eines Prüfbits). 

Beispiel: 7.25 DM soll im ASCII dargestellt werden, also zwei 
Buchstaben (DM), drei Ziffern (725) und zwei Sonderzeichen ( . 
und Blanc). Man erhält demnach die folgenden sieben Bytes 
00110111 00101110 00110010 00110101 00100000 01000100 01001101 
mit dem Achtbitmuster 00100000 als 5. Byte für das Leerzeichen 
bzw. Blanc. 


IBM-Großcomputer verwenden nicht den ASCII, sondern den EBCDI- 
Code (Extended Binary Coded Decimal Interchange Code), der als 
8-Bit-Code 256 (2 hoch 8) verschiedene Möglichkeiten erfaßt. 


1.2.3.2 Hexadezimale Darstellung von Zeichen 


Die 7 Bytes für 7.25 DM sind nicht gerade leicht zu entschlüs- 
seln. Um der besseren Lesbarkeit willen wird man sich Zeichen 
auf dem Bildschirm oder Drucker nicht als Bitmuster ausgeben 
lassen, sondern hexade z ima |] (auch sedezimal oder 
kurz hex genannt). 


Die hexadezimale Darstellung ist umseitig wiedergegeben. 


1.2.3.3 Hauptspeicher als RAM und ROM 


Der Speicher RAM ist ein Schreib-Lese-Speicher (Random Access 
Memory für Direkt-Zugriff-Speicher); der Benutzer kann in den 
RAM Information schreiben bzw. eingeben wie auch aus dem RAM 
Information lesen bzw. ausgeben. Insbesondere bei Personalcom- 
putern ist der Hauptspeicher als RAM ausgebildet, um das An- 
wenderprogramm und die zu verarbeitenden Daten aufzunehmen. 
Häufig ist ein zusätzlicher Teil des Hauptspeichers als Spei- 
cher ROM vorgesehen (vgl. Abschnitt 1.1.1). Auf diesen Nur- 
Lese-Speicher (Read Only Memory) kann der Anwender nur lesend 
zugreifen. Im ROM als Festspeicher werden z.B. Steuerungspro- 
gramme - vom Hersteller fest eingeschmolzen - bereitgestellt, 
die wir zwar anwenden, aber nicht verändern können. 


Die Informationsdarstellung durch die Codes ASCII sowie EBCDI 
gilt für den Hauptspeicher allgemein - unabhängig, ob er nun 
als Speicher RAM oder als Speicher ROM ausgebildet ist. 
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Hexadezimale Dar- 
stellung von 
genau 16 Zeichen 


Darstellung von 7.25 DM im 
ASCII hexadezimal: 
37 2E 32 35 20 44 4D 


Darstellung von 7.25 DM im 
EBCDI-Code hexadezimal: 
F7/ 4B F2 PF5 21 c4 D4 


Die hexadezimale Darstellung 
von 7.25 DM im ASCII sowie 
im EBCDI-Code ist wesentlich 
besser lesbar als die zuge- 
hörige Bitmusterdarstellung. 


Die Übersetzung binär - hex 
besorgt der Computer selbst. 


Die hexadezimale Darstellung 
stellt nur eine Lesehilfe 
dar. Im Hauptspeicher werden 
die Daten nach wie vor binär 
gespeichert und aufgerufen. 





Die Codes ASCII und EBCDI 


Bei Mikrocomputern bzw. Personalcomputern findet man meistens 
den ASCII. 
Der EBCDI hingegen wird bei größeren DV-Systemen verwendet. 
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1.2.3.4 Byte als Maßeinheit für die Speicherkapazität 


Das Byte dient einerseits zur Darstellung von Zeichen und an- 
dererseits zur Angabe der Speicherkapazität 
10 


1 KB = 1 Kilo-Byte = 2 Bytes = 1024 Bytes = ca. eintausend 
Zeichen Speicherkapazität 
1 MB = 1 Mega-Byte = 1000 KB = 1.024.000 Bytes = ca. eine 


Million Zeichen Speicherkapazität 


Die Angabe '64 KB RAM' oder auch einfach '64 K RAM' bedeutet, 
daß dem Benutzer ein Hauptspeicherplatz von ca. 64.000 Zeichen 
Größe für Programm und Daten zur Verfügung steht. 


1.2.4 Speicherung von Information extern auf Datenträgern 
1.2.4.1 Kassette und Magnetband 


Auf Kasse t te werden Daten Bit für Bit hintereinander, 
d.h. bitser ie 11 , aufgezeichnet. Dies ist bei Audio- 
kassettenlaufwerken der Fall wie bei den eigens für den Com- 
putereinsatz entwickelten Recordern. Die 8 Bits 01001101 für 
den Buchstaben M stehen auf Kassette also hintereinander. Auf 
das wesentlich breiteren Magnet band hingegen passen 
die Bits nebeneinander: demnach liegt beim Magnetband eine 
bitpara 1 1] e 1 e Aufzeichnung vor. 


zu unterscheiden sind Start-/Stop-Geräte und Streaming- Geräte: 
Bei den Start-/Stop-Geräten wird blockwei se gespei- 
chert, wobei jeder Block durch Klüfte (Gaps) als Leerräume vom 
nächsten Block getrennt ist. Commodore-Kassetten 2/3000 haben 
z.B. folgendes Aufzeichnungsformat: 

- 10 Sek. Vorspann (leader) 

- 192 Zeichen Fileüberschrift (header) 

- 2 Sek. Kluft (Gap bzw. Vorspann) 


- 192 Zeichen Daten (=1. Datenblock) Datenfile (Daten 
- 2 Sek. Kluft datei) mit 192 
- 192 Zeichen Daten (=2. Datenblock) Zeichen je Block. 


- 192 Zeichen Daten (=n. Datenblock) 
- EOF-Zeichen als Marke für End Of File 





- 10 Sek. Vorspann (leader) 

- 192 Zeichen Fileüberschrift (header) Programmfile mit 

- Programmblock mit 10 KB max 32.000 Zei- 

bis 32 KB Zeichen chen je Block. 

- EOF-Zeichen 
Leerräume bzw. Klüfte kosten Speicherplatz. Sie sind erforder- 
lich, da nur bei gleichmäßiger Bandgeschwindigkeit gelesen und 
geschrieben werden kann. Die Übertragungsraten liegen zwischen 
250 und 1500 Baud bzw. bps (Bits pro Sekunde bei serieller und 
Bytes (Zeichen) pro Sekunde bei paralleler Aufzeichnung). 
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Bei den Streaming - Geräten entfallen die Klüfte und 
Start-/Stop-Marken. Die Daten 'strömen' (to stream) ohne Stops 
in der kompletten Bandlänge in den Hauptspeicher. Streaming- 
Laufwerke werden hauptsächlich zur Datensicherung (Back-Up) 
von Plattendaten (Diskette ,Winchesterplatte) verwendet. Strea- 
mer sind billiger, schneller und speicherplatzsparender als 
Start-/Stop-Cartridges; die kleinste Zugriffseinheit aber ist 
das gesamte Band (vgl. Abschnitt 1.2.4.5). 


Wichtige Einsatzgebiete des Bandes sind die Langzeitarchivie- 
rung, die Datensicherung (Back-Up), der Daten- und Programm- 
austausch sowie -vertrieb (Postversand), die Ersterfassung von 
Daten, die Speicherung von Datenbeständen mit Reihenfolgever- 
arbeitung (z.B. Inventar) und die Programmspeicherung. Im Hin- 
blick auf die Kosten je abgespeichertem Byte schneidet kein 
Datenträger besser ab als das Magnetband als de r typische 
Massenspeicher. 

Muß häufig auf Einzeldaten direkt zugegriffen werden, dann 
scheidet das Band (großes Magnetband wie kleine Kassette) aus. 


1.2.4.2 Diskette, Winchesterplatte und Magnetplatte 


Die Speicheroberfläche der Platte als Direktzugriff-Speicher 
ist stets ähnlich organisiert - ob sie als Diskette im Maxi-, 
Mini- oder Mikroformat eingesetzt wird, als Festplatte in Win- 
chster-Technologie, als große Magneteinzelplatte oder als Mag- 
netplattenstapel. Am Beispiel des Softsektor-Formats IBM 3740, 
das bei Mini-Disketten fast zum Standard geworden ist, wollen 
wir die Speicherorganisation der Platte genauer erklären. 


Eine neu gekaufte Diskette ist leer, sie ist weder beschrieben 

noch irgendwie unterteilt. Beim Softsektor-Format IBM 3740 ist 

die Formatierung (Form der Speicheroberfläche festlegen) bzw. 

Sektorierung (Oberfläche in Sektoren als Abschnitte eintei- 

len) softwaremäß ig durch ein spezielles Programm 

wie folgt vorzunehmen: 

- 77 kreisrunde Spuren vorsehen; bei 2seitiger Diskette bilden 
gegenüberliegende Spuren je einen Zylinder. 

- Jede Spur in gleichlange Sektoren (Abschnitte) gliedern: 26, 
15 oder 8 Sektoren/Spur, je nach der Sektorlänge von 128, 
256 oder 512 Bytes. 

- Spuren numerieren von Spur 00 (außen) bis Spur 76 (innen). 

- Verwendung festlegen: Spur 00 für Inhaltsverzeichnis, Spuren 
01-74 für Benutzerinformation, Spuren 75-76 Fehlerreserve. 

- Die Sektoren durch Klüfte bzw. Gaps trennen, um auf den Sek- 
tor als kleinste Zugriff seinhei t bei 360 Um- 
drehungen/Minute fehlerfrei zugreifen zu können. 

- Die Sektoren unterteilen in ID-Feld (=Identifikationsfeld 
als Adreßfeld) und Daten-Feld (=Benutzerinformation 128, 256 
oder 512 Bytes lang). 
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Speicherorganisation der Platte am Beispiel des 
Softsektor-Formates IBM 3740 für Disketten 


Eine Spur hat weder Anfang noch Ende. Wenn eine Lichtschranke 
das Index 1 och überfährt, wird durch einen Impuls der 
'Spurbeginn' angezeigt. 

Im Gegensatz zur hier erklärten Softsektorierung wird bei der 
hardsektoriert en Diskette die Einteilung hard- 
waremäßig bereits vom Hersteller vorgenommen. 


Bei Einzelplatten wird bit ser i e |] 1] auf Spuren aufge- 
zeichnet. Die 8 Bits 01001101 für M im ASCII stehen also der 
Reihe nach hintereinander (z.B. auf Spur 34). 

Beim Magnetplattenstapel kann zylinderweise auf den jeweils 
unmittelbar übereinanderliegenden Spuren aufgezeichnet werden. 


1.2.4.3 Klarschriftbeleg als Druckerausgabe 
Auf einem Klarschriftbeleg wird Information in einer für den 
Menschen s o w i e den Computer lesbaren Form extern gespei- 


chert (vgl. Abschnitt 1.2.1.2). Hier die Zeichendarstellung 
bei der heute besonders weit verbreiteten Klarschrift OCR-A: 


ABCDEFGHIJKLMNOPARSTU 
VUXYZ 0123456 78% 


Klarschriftbelege werden durch Klarschriftdrucker erstellt, 
bei denen es sich vornehmlich um Typenraddrucker handelt. Hier 
eine kleine Übersicht der Druckertypen all gemein: 








- Zu unterscheiden sind mechanische Drucker (impact) und nicht 
mechanische Drucker (non-impact), serielle Drucker (Zeichen 
für Zeichen drucken) und Zeilendrucker (zeilenweise drucken) 
sowie in einer Richtung und vor/rückwärtsschreibende Geräte. 

- Bei den mechanischen Drucker überwiegen Typenraddrucker und 
Matrixdrucker. 
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- Doeprr Typenraddrurcke r hat Typen an Armen (Spei- 
chen) des Typenrades befestigt. Die Räder lassen sich aus- 
wechseln - und damit auch die Schrifttype sowie die Zeichen- 
dichte (z.B. 1/10" = 132 Zeichen/Zeile, 1/12" = 158 Zeichen/ 
Zeile, 1/15" = 198 Zeichen/Zeile). 

Typenraddrucker werden dort eingesetzt, wo es auf die Druck- 
qualität ankommt: z.B. in der Textverarbeitung und der Klar- 
schrifterfassung. Man nennt die auch 'Schönschreibdrucker'. 

- Door Matr ixdrucker erzeugt Zeichen in Form ei- 
ner matrixförmigen Anordnung von Einzelpunkten. Je mehr Roh- 
re bzw. Nadeln pro Matrix (z.B. 7*9- und 7*%5-Matrix), desto 
besser ist das Druckbild. Kann man Matrixpunkte einzeln an- 
steuern, läßt sich der Matrixdrucker zur Ausgabe von Grafik 
(wie Kurven und Bildern) verwenden. 

- Nicht-mechanische anschlagsfreie Drucker arbeiten leiser 

und schneller als Impact-Drucker: dabei handelt es sich um 
Tintenstrahldrucker (Ink-Jet) oder um 
elektrofotografische Verfahren kombiniert mit Laserstrahlen; 
beide Druckertypen arbeiten mit Normalpapier. 
Spezialpapier benötigen die Thermodrucker (wär- 
meempfindliches Papier), die elektrostatischen Drucker (Die- 
lektrikum auf dem Papier) und die Elektroerosionsdrucker 
(Kondensatorpapier). 


1.2.4.4 Schnittstellen als Bindeglieder CPU - Peripherie 


Soll der Informationsaustausch zwischen der CPU und den ange- 
schlossenen Peripheriegeräten bzw. Datenträgern klappen, dann 
müssen die Einheiten zueinander passen, d.h. kompatibel (oder 
besser: steckerkompatibel) sein. Genau als solche Steckverbin- 
dungen kann man sich die Schnittstellen (engl. 
Interfaces) vorstellen. Damit Geräte verschiedener Herstel- 
ler miteinander verbunden werden können, müssen die Schnitt- 
stellen der Geräte genormt sein. Die vier bei Personalcompu- 
tern zumeist anzutreffenden Schnittstellen sind die V.24-, 
die TTY-, die Centronics- und die IEC-Bus-Schnittstelle. 


- Die V.24-Schnittstelle ist eine asynchrone, serielle Schnitt- 
stelle: asynchron bedeutet, daß 2 Geräte trotz verschiede- 
nen Arbeitsgeschwindigkeiten einander angepaßt werden kön- 
nen; seriell heißt, daß Bit für Bit nacheinander übertragen 
werden. Die US-Schnittstelle RS-232-C entspricht der V.24. 
Beide Interfaces findet man in der Datenfernverarbeitung. 


- Als weitere serielle Schnittstelle wurde die TTY-Schnitt- 
stelle vom Fernschreiber (Teletype) übernommen zum Anschluß 
von Bildschirm und Drucker. 


- Nach dem Druckerhersteller Centronics benannt ist eine wei- 
tere Schnittstelle, mit der Drucker anderer Fabrikate ausge- 
rüstet sind. Als parallele Schnittstelle werden 
alle Bits eines Zeichens (Byte) über 8 parallele Leitungen 
übertragen (gleichwohl: bitparallel, aber zeichenseriell). 
Die Centronics-Schnittstelle ist heute zum Quasi-Standard 
bei Druckern geworden; dabei wird zumeist ein 36-poliger 
AMP-Stecker verwendet mit nur teilweise genormter Pinbele- 
gung (exakte Belegung der Pins dem Handbuch zu entnehmen). 
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- Die IEC-Bus-Schnittstelle umfaßt 8 Daten-, 3 Quittungs- und 
5 Steuerleitungen, um bis zu 15 Peripheriegeräte an einen 
Computer anzuschließen. 


Exakt beschriebene Schnittstellen gehen einher mit dem Trend 
zur "Mixed Hardware' als dem Zusammenschluß von Peripheriege- 
räten unterschiedlicher Herstellermarken. Dies wiederum führte 
zur steten Ausweitung des OEM-Marktes (Original Equipment Ma- 
nufacturer). Ein OEM ist ein Gerätehersteller, der seine Pro- 
dukte nicht (nur) an Endabnehmer verkauft, sondern ebenso an 
andere Hersteller; auf dem OEM-Markt besorgen sich Computer- 
hersteller Peripherie-Geräte, die sie in ihr System integrie- 
ren. So kann sich z.B. hinter dem IBM-Typenschild eines Druck- 
ers, den IBM für seinen Personalcomputer anbietet, durchaus 
ein EPSON-Drucker verbergen. 


1.2.4.5 Back-Up-Systeme zur Datensicherung 


Für Personalcomputer -autonom als Stand-alone-Systeme genutzt- 
bietet sich folgender Mix für die externen Speichergeräte an: 


Datenverarbeitung Datensicherung 


Für die Daten: | Für die Programme: | 
IWNINCHESTER-PLATTE | DISKETTE (FLOPPY) | |MAGNETBAND 
als Festplatte ı als Wechselplatte als Massenspeicher 


RR Wut 


Externspeicher zur Datenverarbeitung und zur Datensicherung 


Für Daten/Programme: 














Festplatten-Laufwerke bringen dem Anwender von Personalcompu- 
tern die gewünschten hohen Speicherkapazitäten, zugleich aber 
auch das Problem der Datensicherung bzw. des Back-Up ( 1 DIN- 
A4-Seite = ca. 2 KBytes; 20 MBytes auf einer Festplatte = ca. 
10 Karl-May-Bücher; 1 MBytes eintippen = ca. 10 Manntage). Bei 
Programm- oder Bedienungsfehler, Defekt des Externen Speichers 
oder des Computers selbst könnten die Daten zerstört werden; 
deshalb müssen Sicherungskopien der Daten erstellt werden. Bei 
Back-Up-Systemen als Reserve- bzw. Sicherungssysteme (Back-Up 
heißt: Zeichen für Zeichen z.B. auf Band kopieren) gibt es 
Disketten, Wechselplatten und Bänder als Sicherungsdatenträger 
(letztere im Start-Stop- sowie im Streaming-Betrieb (Abschnitt 
1.2.4.1)). Mit dem zunehmenden Umfang der zu sichernden Daten- 
bestände wird sich das Magnetband als Streamer durchsetzen: so 
kann ein Cartridge-Tape-Streamer den Inhalt einer 20-MB-Fest- 
platte in wenigen Minuten kopieren und damit sichern. 


Bei dieser Art der Datensicherung werden die Sicherungskopien 
in einem gesonderten Arbeitsgang z.B. allabendlich oder zwei- 
mal je Woche durchgeführt. Anders geht dass Loggingvor, 
bei dem sämtliche über Tastatur eingegebenen Daten von einem 
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Datensicherungsprogramm automatisch auf einer Zusatzdatei mit- 
geschrieben werden; diese Datei wird auch '"Log-Datei' genannt. 
Die Datensicherung wird also bereits im Rahmen der Datenerfas- 
sung vorgenommen - dieser Erfassung wenden wir uns jetzt zu. 


1.2.5 Verfahren der Datenerfassung 


Datenerfassung heißt, Daten in computerlesbare 
Form bringen (vgl. Abschnitt 1.2.1.1) und umfaßt den Weg von 
der Entstehung der Daten bis zu deren Eingabe in die CPU. Da 
im kaufmännischen Bereich ca. 90% des Zeitaufwandes auf diesen 
weg entfallen, ist der Kostenanteil der Datenerfassung relativ 
hoch anzusetzen. 
Die unterschiedlichen Verfahren der Datenerfassung 
werden festgelegt durch vier Faktoren: 
1) Anzahl der Stufen, die die Daten von der 
Entstehung bis zur Eingabe durchlaufen. 
2) Verbindung zwischen Erfassungsgerät und CPU zum Zeitpunkt 
der Erfassung: off - line oder on - line. 
3) Zentrale oder dezentrale Durchführung 
der Erfassung. 
4) Erfassungsgerät mit eigener Inte 11 i gen zZ ausge- 
stattet oder nicht. 
Auf diese Faktoren wollen wir nun im Überblick näher eingehen. 


Zunächst ist eine einstufige, zweistufige und dreistufige Da- 
tenerfassung zu unterscheiden. 





Die "klassische Datenerfassung’ durchläuft drei Stufen: Er- 
stellen des Urbelegs, Übernehmen auf Datenträger und Eingeben 
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in die CPU. Werden Urbeleg und Datenträger gleichzeitig er- 
stellt, dann verkürzt sich das Vorgehen auf zwei Stufen. Mit 
der Bildschirmerfassung sowie der Erfassung über Scanner bzw. 
Lesestift kommt man zur einstufigen Direkterfassung. Beispiel: 
POS - System (Point-of-Sales-System, Verkaufspunkte-System). 


Bei der Off-line-Erfassung erfolgen Erfassung und Verarbei- 
tung vollständig getrennt voneinander. Beim Datensammelsystem 
z.B. wird zunächst von mehreren Erfassungsplätzen ein gemein- 
samer Datenträger erstellt, der dann später zur Verarbeitung 
weitergegeben wird. 

Bei der On-line-Erfassung gelangen die Daten direkt in die CPU 
(an die Stelle des Datenträgertransports tritt also die Daten- 
übertragung). Der große Vorteil der on-line gegenüber der off- 
line durchgeführten Erfassung liegt in der Zeitersparnis. Als 
nachteilig kann sich der Umstand auswirken, daß während der 
Erfassung die CPU für andere Arbeiten blockiert ist. 


Dezentrale Erfassung heißt, Daten am Ort ihrer Entstehung zu 
erfassen - z.B. im Lager und beim Verkauf. Die mobile Datener- 
fassung über tragbare Personal- u. Mikrocomputer zählt hierzu. 
Bei der zentralen Erfassung hingegen bringt man alle Urbelege 
an eine bestimmte Stelle (Beispiel: Datensammelsystem). 


Datenerfassungsgeräte werden zunehmend mit eigener Intelligenz 
ausgerüstet. Oder anders ausgedrückt: Zur Erfassung greift man 
immer häufiger auf Mikrocomputer zurück, die z.B. wahlweise 
on-line an einen Großcomputer angeschlossen sind und off-line 
als selbständige Computereinheit (Stand-alone-System) genutzt 
werden. 


1.2.6 Computertypen 


Zunächst: Wenn vom "'Computer' die Rede ist, dann ist damit im- 
mer der frei programmierbare Allzweckrechner bzw. General-Pur- 
pose-Computer gemeint, nicht jedoch der Spezial-"Computer" wie 
z.B. eine Datenbank-Maschine (vgl. Abschnitt 1.3.5.6) oder ein 
Textverarbeitungs-Automat. 

zu den zahlreichen Typologien für Computer soll hier keines- 
falls eine weitere hinzugefügt werden. Anhand der beiden Ex- 
treme "'Personalcomputer' und "'Großcomputer' soll allein eine 
Orientierungshilfe gegeben werden. 


1.2.6.1 System-Konfigurationen für Personal- und Großcomputer 


Eine System-Konfiguration gibt an, wie periphere Einheiten um 
eine CPU zu einem funktionsfähigen DV-System zusammengestellt 
sind. Zunächst eine Gerätezusammenstellung, wie sie für Perso- 
nalcomputer typisch ist. Die Geräte werden dabei zeichnerisch 
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Für Personalcomputer typische System-Konfiguration 


durch Sinnbilder dargestellt, die nach DIN 66001 genormt sind. 
Der Personalcomputer -für den persönlichen Gebrauch und durch- 
aus auch zur beruflichen Nutzung gekauft- soll hier nicht von 
Bezeichungen wie Privat-Computer, Tischcomputer, Heimrechner, 
Spielcomputer und Kleinrechner abgegrenzt werden; dazu schrei- 
tet die Entwicklung viel zu schnell voran. Vielmehr soll der 
Personalcomputer als extremes Gegenstück zur 
Kategorie der Großcomput er aufgefaßt werden „ die 
z.B. mit je fünf Band- und Platteneinheiten als Externspeicher 
ausgerüstet sein können. Großcomputer werden in Rechenzentren 





Für Großcomputer typische System-Konfiguration 


betrieben - sei es im unternehmenseigenen Rechenzentrum oder 
im Sevice-Rechenzentrum von einem freien, herstellereigenen 
bzw. kooperativen DV-Dienstleistungsunternehmen. Die Sinnbil- 
der für Band und Platte werden oft auch für Kassette und Dis- 
kette verwendet. 

zwischen dem Personalcomputer als unterem und dem Großcomputer 
als oberem Extrem gibt es zahlreiche Abstufungen wie z.B. An- 
lagen der Mittleren Datentechnik (MDT), Minicomputer, Büro- 
Computer oder auch Small-Business-Computer. Ebenso können meh- 
rere Computer zu einem Rechnerverbund vernetzt sein (Netzwerk) 
mit Satelliten-Computern, die selbständig als Stand-alone- 
System und/oder on-line mit einem Haupt-Computer arbeiten. Da- 
bei sind Personalcomputer häufig Teil eines Großcomputers. 
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Großcomputer werden oft als Mainframe s bezeichnet 
und damit von der anschließbaren Peripherie abgegrenzt. Per- 
sonalcomputer zählen immer häufiger zu dieser Peripherie. 


1.2.6.2 Eigenschaften von Personalcomputern 
Personalcomputer weisen allgemein folgende Eigenschaften auf: 


]) Autonom arbeitendes DV-System mit zumindest einem 
Externspeicher. 

2) CPU mit mindestens 64 KB RAM für Benutzerdaten und 
Benutzerprogramme. 

3) Verfügbarkeit mindestens einer höheren Programmier- 
sprache (Basic, Pascal, Forth, ...). 

4) Möglichkeit, in Maschinensprache (Assembler) zu 
programmieren. 

5) Betriebssystem ermöglicht Dialog zwischen 
Benutzer und Computer. 

6) Exakt beschriebene Schnittstellen. 


Wünschenswert ist, daß Personalcomputer hardwaremäßig wie auch 
softwaremäßig kompatibel sind. So sollten Programmiersprachen 
wie Basic und Pascal genormt sein, für die Externspeicher ein- 
heitliche Aufzeichnungsformen übernommen werden (z.B. für Dis- 
ketten das Softsektor-Format IBM 3740) und übereinstimmende 
Schnittstellen definiert sowie steckermäßig vorgesehen sein 
(z.B. gesamten Systembus an eine Steckerleiste herausführen, 
damit der Anwender das System später erweitern kann). Doch wa- 
rum auch soll eine CBM-Floppy zu einem Apple passen, wenn ein 
Opel-Vergaser nicht zu einem Ford paßt; und warum soll das BA- 
SIC-Programm eines Alphatronic auf einem IBM-PC laufen, wenn 
das Motoröl eines VW nicht für einen Mercedes geeignet ist? 


Häufig werden für Mikrocomputer die vier Kategorien Handcompu- 
ter (HC), Videocomputer (VC), Personalcomputer im engeren Sin- 
ne (PC) und Tragbare Computer (Portables) gebildet. 


Ha. TQ vera’ mi DB WVIETeETEr IBELI 
Hand-Held-Computer, Pocket-Computer, Brieficase-Computer. 
Tastatur mit Zeilendisplay, Module. Taschenrechnerformat. 


VIrd er0-.03,6 nn BrurEre 2 IVCYE 
Tastatur mit Videoanschluß; zunehmend Diskettenlaufwerke 
anschließbar. Ausbaumöglichkeit in Richtung PC. 


Bart Bon are nd tere Hero? 
Tastatur, Diskette und/oder Hard-Disk, Monitor. Zunehmend 
16-Bit-Mikroprozesor. Monitor, Mehrere Betriebssysteme, 


Br tiah- Le U a 1: BER oa > a = = Wi > 
Tastatur, CPU, Diskette und Monitor als eine Einheit, als 
Koffer tragbar. 


Vier Kategorien von Mikrocomputern 


Daneben unterscheidet man nach der Nutzungsart Homecomputer 
(privat) und professionelle Computer (beruflich). 
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Die VCs müssen an einen Bildschirm angeschlossen werden. Dies 
kann ein normales Fernsehgerät sein, das jedoch aufgrund der 
geringen Auflösung (960 Zeichen pro Bild) für Grafik wie auch 
längere Benutzung nur bedingt geeignet ist. Auch VCs benötigen 
einen Monitor (ca. 2000 Zeichen pro Bild), der eine wesentlich 
ruhigere Bildwiedergabe bietet. 

Die Portables -Neuentwicklungen oder aber Abkömmlinge von be- 
reits bewährten PCs- werden häufig zur mobilen Datenerfassung 
eingesetzt. 

Vergleicht man den Markt der Mikros mit dem der PKWs, so stel- 
len die PCs die 'normalen' Limousinen dar, während HCs, vVCs 
und Protables dann die Minis, Cabrios usw. ausmachen. 


1.2.6.3 Personalcomputer im Computer-Netzwerk 


Sinkende Hardware-Kosten und eine ständig zunehmende Zahl von 
Informationsquellen führen immer häufiger zur Vernetzung meh- 
rerer Personalcomputer zu einem lokalen Net z . Das 
Attribut 'lokal!' verweist auf einen begrenzten Wirkungsbereich 
wie eine Abteilung oder ein Gebäude (sog. Inhouse-Netz); auch 
hierzulande spricht man dabei von LANs (Local Area Network). 


Es gibt Netze mit Stern-, Ring- oder Bus-Struktur. Bei stern- 
förmiger Anordnung ist jeder Computer mit einer zentralen Ein- 
heit verbunden, die verwaltet und die Netz-Leistung begrenzt; 
fällt sie aus, so bricht das gesamte Netz zusammen. Die Ring- 
Anordnung ist billiger, doch auch hier führt der Ausfall einer 
Station zum Ausfall des gesamten Netzes. Dies ist nicht so bei 
der Bus-Anordnung als weitverbreitetem Konzept: über eine Sam- 
melschiene kann jede Station mit jeder Station in Kontakt tre- 
ten. Das von Xerox, Intel und DEC entwickelte Netz "Ethernet' 
weist eine Bus-Struktur auf und stellt durch seine große Ver- 
breitung einen Quasi-Standard dar. 

Es gibt Netze mit und ohne Master-Controller. Der Masterbild- 
schirm weist die höchste Priorität auf und ist zumeist softwa- 
remäßig ansteuerbar; gegenüber der hardwaremäßigen Verdrahtung 
ist dies bei Ausfall des Masterbildschirms (andere Station als 
Master ansteuern) von Vorteil. 

EIn Netz verfügt oft nur über einen oder zwei Drucker, die mit 
Drucker - Spo o 1 in g angesteuert werden. Anstatt Daten 
direkt auf den Drucker auszugeben, "'drucken' die Stationen 
auf eine Platte (Zwischenspeicher), deren Information automa- 
tisch durch ein Spooler(-programm) ausgedruckt wird. 
Spool steht für "simultaneous peripheral operations on-line’. 


Personalcomputer finden nicht nur intern im lokalen Netz Ver- 
wendung, sondern ebenso im öffentlichen Netz 
extern. So im BTX-Netz als BTX-Editierplatz des Informations- 
anbieters, als BTX-Terminal des Konsumenten oder als Kommuni- 
kationssystem für kleinere Firmen. 

Nach Datex, Datex-L, Telex, Teletex und BTX werden Personal- 
computer sicher auch in dem von der Post geplanten Netz ISDN 
(Integrated Services Digital Network) eingesetzt werden, das 
Daten, Text, Standbilder wie auch Sprache übermitteln wird. 
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Personalcomputer werden von Beginn an primär als Stand - 
Alone - Syst em autonom für sich alleine verwendet. 
Man spricht auch vom Single-User-Betrieb. 

Vernetzt man mehrere Personalcomputer, so gelangt man zu einem 
Multi - User - Betr i eb, bei dem mehrere User 
(Benutzer) über ihre PCs als Terminals verbunden sind. 
Single-User-Betrieb wie auch Multi-User-Betrieb können unter 
Multitasking laufen; dabei werden mehrere Aufgaben 
als Tasks quasi gleichzeitig durch e i ne CPU abgearbeitet. 
Multiusing und Multitasking stellen hohe Anforderungen an das 
Betriebssystem (z.B. MP/M und Concurrent CP/M; siehe Abschnitt 
1.3.6.6). 


1.3 Software = Daten + Programme 


1.3.1 Software im Überblick 


Software ist Information und wird unterteilt in 
Daten und Programme (vgl. Abschnitt 1.1.1). Auf 
diese beiden Komponenten der Software wollen wir nun eingehen. 


1.3.1.1 Begriffsbildungen für Daten 


Sieben wichtige Begriffspaare für Dat en wollen wir näher 
betrachten. 


Stammda t en bleiben normalerweise über einen längeren 
Zeitraum hinweg konstant (z.B. Artikelstammdaten, Kundenstamm- 
daten, Personalstammdaten), Änderungsdaten die- 
nen der Anpassung von Stammdaten. 

Im Gegensatz zu Stammdaten erfahren Bestandsdaten 
oftmalige Änderungen, die durch Bewegungsdaten 
vorgenommen werden (Zugang für + und Abgang für -); letztere 
werden kurz auch als Bewegungen bezeichnet. Die Lagerbestands- 
fortschreibung nach der Formel "Anfangsbestand + Zugänge - Ab- 
gänge ergibt Endbestand' gehört in diese Kategorie von Daten. 
Ordnungsdaten legen eine Speicherungs-, Sortier- 
bzw. Verarbeitungsfolge fest, Mengendat en hingegen 
eine Anzahl (Stück, Größe, Gewicht, Preis). 

Mt numerischen Dat en bzw. Zahldaten rechnet 
jeder Computer, nicht jedoch mit Textdaten. Letztere 
umfassen beliebige Zeichen, die stets zwischen Gänsefüßchen 
oder Hochkommata stehen, und werden auch als alphanumerische 
Daten, als Zeichenkettendaten oder als Strings bezeichnet. 
Unforma.tierte Dat en weisen keine einheitli- 
che Form auf. In der kommerziellen Datenverarbeitung überwie- 
gen formatierte Daten : auf einem Rechnungs- 
formular stehen z.B. die Dezimalpunkte der DM-Beträge unter- 
einander, jeweils auf 2 Nachkommastellen gerundet. 
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Sieben Begriffspaare für Daten 


Mit die wichtigste Unterscheidung ist die von einfachen Daten- 
typen und Datenstrukturen: 

Einfache Datentypen bestehen aus jeweils 
nur einem einzigen Datum, so aus einer Ganzzahl (INTEGER), aus 
einer Dezimalzahl (REAL) oder aus einem Textwort (STRING). Die 
Datenstrukturen als strukturierte Datentypen 
hingegen umfassen jeweils mehrere Daten, die unterschiedlich 
z.B. als Feld (ARRAY), Verbund (RECORD) oder Datei (FILE) an- 
geordnet sein können. In Abschnitt 1.3.5 werden die Datentypen 
im Zusammenhang mit der Datei genauer erklärt. 


Einzeldaten und kleinere Datenbestände lassen sich innerhalb 
eines Programmes speichern, so z.B. der Rabattsatz in einem 
Rechnungsschreibungsprogramm. Die umfangreichen in der kommer- 
ziellen Datenverarbeitung zu verarbeitenden Datenbestände wer- 
den getrennt vom Programm als Dat ei auf Platte 
oder Band als externem Speicher untergebracht. 


1.3.1.2 Begriffsbildungen für Programme 


Man unterscheidet Anwenderprogramme sowie Systemprogramme. 
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Programme 
Anwenderprogramme Systemprogramme 

vom Anwender von Software- Steuer- Dienst- Übersetzer- 
selbst haus fremd pro- pro- programm 
erstellt bezogen gramm gramm 
z.B. eigene us A Z«B. z.B, BASIC, 
Rechnungs- Tabellen- Dialog Sortier- PASCAL, 
schreibung kalkulation Mensch- programm Cobol, 

Computer FORTH, € 


Anwenderprogramme (Problem) und Systemprogramme (Computer) 


Anwenderprogramme lösen die konkreten Prob- 
leme des jeweiligen Anwenders und werden auch Benutzer- bzw. 
Arbeitsprogramme genannt oder unter der Bezeichnung Anwender- 
Software zusammengefaßt. Anwenderprogramme können vom Anwender 
selbst erstellt und programmiert oder fremd von einer Soft- 
warefirma bezogen sein. Zwischen diesen beiden Extremen gibt 
es zahlreiche Abstufungen: so z.B. im Falle der individuellen 
Anpassung standardisierter Anwender-Software. Auf das Anpassen 
wie auch Erstellen von Anwenderprogrammen gehen die Abschnitte 
1.3.7 und 1.3.8 näher ein. 


Gegenstück sowie Ergänzung zu den Anwenderprogrammen sind die 
Systemprogramme , deren Gesamtheit als Betriebs- 
system bezeichnet wird, da sie den geordneten Betrieb 
des jeweiligen DV - Sys te ms gewährleisten. Ganz allge- 
mein wird das Betriebssystem oft als OS (Operating System) und 
als DOS (Disk Operating System, da plattenorientiert) bezeich- 
net. Jedes Betriebssystem umfaßt drei Arten von Systemprogram- 
men: 

Die Steuerprogramme steuern das Zusammenwirken 
der Peripherie mit der CPU und die Ausführung eines Programns. 
Die Dienstprogranme bzw. Utilities sind zwar 
nicht unbedingt notwendig, werden aber als unerläßlicher Kom- 
fort zum einfachen und benutzerfreundlichen Betrieb des Compu- 
ters angesehen (ein Programm zur Herstellung einer Disketten- 
kopie gehört eben einfach 'dazu'). Steuer- und Dienstprogramme 
bilden oft eine Einheit: ein Editor z.B. dient zumeist 
nicht nur dem Eintippen und Bearbeiten von Programmtext über 
einen Bildschirm, dem sog. Editieren also, sondern ebenso dem 
Abspeichern dieser Texteingabe auf Diskette oder Band, und da- 
mit der Ein-/Ausgabesteuerung. 

Ein Übersetzerprogramm übersetzt ein in 
einer Programmiersprache wie z.B. BASIC codiertes Anwenderpro- 
gramm in die Muttersprache des Computers, bzw. in die 0/1-Form. 
Das ist vergleichbar mit der Tätigkeit eines Dolmetschers, 
der Sätze aus einer Fremdsprache (z.B. Englisch) in die eige- 
ne Muttersprache (z.B. Deutsch) übersetzt. Ein Computer ver- 
steht so viele Fremdsprachen bzw. Programmiersprachen, wie 
Übersetzerprogramme vorhanden sind. Die meisten Personalcompu- 
ter verstehen die Programmiersprachen BASIC und z2.T. PASCAL, 
da die zugehörigen Übersetzerprogramme beim Kauf automatisch 
mitgeliefert werden. 
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Was für das Auto das Benzin bedeutet, um von Astadt nach Bdorf 
fahren zu können, das bedeutet für die Computer-Hardware das 
Betriebssystem , um ein Anwenderprogramm ausfüh- 
ren zu können. In Abschnitt 1.3.6 wenden wir uns dem Betriebs- 
system genauer zu. 


Wie für Daten allgemein Datenstrukturen unterschieden wurden, 
so werden für Programme (Anwender- wie Systemprogramme) übli- 
cherweise vier Programmstruk turen definiert. 


(1) Folgestrukturen: Lineare Prgramme 

(2) Auswahlstrukturen: Verzweigende Programme 

(3) Wiederholungsstrukturen: Programme mit Schleifen 

(4) Unterprogrammstrukturen:; Programme mit Unterabläufen 


Vier grundlegende Programmstrukturen 


Diese Programmstrukturen werden als "Bausteine der Software' 
bezeichnet, da die Analyse noch so komplexer Programmabläufe 
stets zu diesen Strukturen als Grundmuster führt. Abschnitt 
1.3.3 erklärt diese Programmstrukturen an kleinen Beispielen 
und Abschnitt 1.3.4 im Zusammenhang mit den Datenstrukturen. 


1.3.2 Datentypen und Datenstrukturen 


Im vorangehenden Abschnitt wurden sieben Daten-Begriffe ange- 
führt, darunter der Begriff des Datentyps . Dieser 
Begriff ist grundlegend für die Programmierung. Wir wollen ihn 
erklären: es gibt einfache und strukturierte, statische und 
dynamische sowie standardmäßig vorhandene und benutzerseitig 
definierbare Datentypen. 


1.3.2.1 Einfache Datentypen als 'Moleküle' 

Einfache Datentypen lassen sich nicht weiter zerlegen und wer- 

den deshalb auch als elementare, skalare sowie unstrukturierte 

Datentypen bezeichnet. Diese Typen enthalten deswegen stes nur 

ein einziges Datum und stellen sozusagen die 'Moleküle' der 
Bezeichnung: Beispiel: Wertebereich: 


CHAR Einzelzeichen D Zeichen (numerisch, al- 
pha, Sonderzeichen) 


INTEGER Ganzzahl 126 Ganze Zahlen 
REAL Dezimalzahl 126.75 Zahlen mit Dezimalpunkt 
STRING Text, Zeichen- "DM-Wert" Gesamter Zeichen- 

kette vorrat des Computers 
BOOLEAN Logisch 1 Wwahrheitswerte TRUE (1, 


wahr), FALSE (O,unwahr) 


Fünf einfache bzw. elementare Datentypen 
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Daten dar, da sie vom Programmierer nicht - so ohne weiteres - 
unterteilt werden können. 

Der Datentyp CHAR umfaßt nur e i n Zeichen. Als STRING (Text) 
gilt alles, was zwischen Gänsefüßen steht, also auch der Text 
"99,50 DM Endsumme". Numerische Typen sind INTEGER oder REAL. 
Der Datentyp BOOLEAN kennt nur die 2 Werte TRUE (z.B. Stamm- 
kunde) oder FALSE (kein Stammkunde). 


1.3.2.2 Datenstrukturen als strukturierte Datentypen 


Strukturierte Datentypen sind neben anderen der ARRAY (Liste) 
und der RECORD sowie das FILE. Dabei werden mehrere Daten un- 
ter einem Namen zusammengefaßt abgelegt. Der ARRAY wird auch 
als Feld, Tabelle und Bereich bezeichnet und enthält Komponen- 


Bezeichnung: Beispiel: Kennzeichen: 


ARRAY (eindimensional) [12 3 44 56 21 Komponenten alle mit 
Vektor denselben Datentypen 
(hier 5 Mengen) 


ARRAY (zweidimensional) 
Matrix 


Komponenten alle mit 
denselben Datentypen 
(hier 4*3=12 Preise in 
4 Zeilen u. 3 Spalten) 





RECORD 101 (=Nrr) Komponenten mit unter- 
Verbund, auch Satz FREI (=NAME) schiedl. Datentypen 
65000 (=UMSATZ) (hier: INTEGER, STRING 
u. REAL (Kundensatz)) 


SET (} (1) (2) (12) Komponenten sind Teil- 
Menge für SET OF 1..2 mengen der Grundmenge 
FILE über 1000 Sätze Datei als Sammlung von 
Datei der KUNDENDATEI Datensätzen auf einem 
Externspeicher 


Vier wichtige Datenstrukturen 


ten bzw. Elemente gleichen Typs. Beim eindimensionalen ARRAY 
sinddie Elemente in Reihe angeordnet wie im Beispiel die 5 Wo- 
chentagabsatzmengen 12, 3, 44, 56 und 21 „ während sich der 
zweidimensionale ARRAY in zwei Richtungen ausdehnt: waagerecht 
in Zeilen (hier 4 Zeilen) und senkrecht in Spalten (hier 3 
Spalten). Es gibt nicht nur Integer-Arrays (alle Elemente sind 
ganzzahlig) und Real-Arrays (alle Elemente sind Kommazahlen), 


sondern z.B. auch String-Arrays wie "MO, DI, MI, DO, FR, SA' 
oder "HAMMER, MEISEL, SAEGE' (alle Elemente sind Textworte). 


Im Gegensatz zum ARRAY können im RECORD auch Daten verschiede- 
ner Datentypen abgelegt sein. Der oben wiedergegebene RECORD 
verbindet drei Komponenten vom Typ INTEGER (Kundennummer ganz- 
zahlig), STRING (Kundenname stets Text) und REAL (Kundenumsatz 
als Dezimalzahl) - deshalb auch die Bezeichnung "Verbund'. In 
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der kommerziellen DV entspricht diese Datenstruktur häufig den 
Datensätzen bzw. Komponenten von Dateien wie hier der Kunden- 
datei. 


Unter einer Datei versteht man allgemein eine Sammlung von Da- 
tensätzen, die getrennt vom Programm auf einem Externspeicher 
(Diskette, Platte, Kassette, Band) als selbständige Einheit 
gespeichert sind. Die Datensätze stellen die Datei-Komponenten 
dar und weisen alle denselben Datentyp auf, d.h. sie sind alle 
z.B. vom Typ RECORD oder alle vom Typ ARRAY. Eine Datei bzw. 
ein FILE kann viel größer sein als der im Hauptspeicher ver- 
fügbare Speicherplatz. 


1.3.2.3 Statische und dynamische Datentypen 


Datenstrukturen können statisch oder aber dynamisch vereinbart 
sein. 

Statische Datentypen behalten während der Programm- 
ausführung ihren Umfang unverändert bei. Beispiel: Beim Beginn 
eines Programms wird vereinbart, daß ein eindimensionales Feld 
bzw. Array mit 5 Elementen zur späteren Aufnahme und Verarbei- 
tung der Absatzmengen für die 5 Wochentage Mo - Fr eingerich- 
tet wird. Statisch heißt, daß die Anzahl der Feldelemente wäh- 
rend der Programmausführung gleich bleibt, während sich ihre 
jeweiligen Inhalte ändern können. 


Bei dynamische n Datentypen muß die Anzahl der Kom- 
ponenten nicht bereits beim Schreiben des Programms festgelegt 
werden, sondern erst im Zuge der Programmausführung. Die Datei 
bzw. das FILE ist stets als dynamischer Datentyp vereinbart. 
Warum? Beim Anlegen einer Kundendatei werden z.B. 455 Kunden 
in 455 Datensätzen auf Diskette erfaßt. Diese Zahl von 455 Da- 
teikomponenten muß veränderbar sein, um neue Kunden aufnehmen 
und Ex-Kunden löschen zu können. Da die Änderungen aber 'tri- 


Datenstrukturen 

STATISCH DYNAMISCH 
Werte ändern sich, niemals Werte sowie Struktur (Anzahl, 
aber die Anzahl. Aufbau) ändern sich. 
Anzahl der Komponenten Anzahl und Aufbau der Kompo- 
ist konstant, nenten ist variabel. 
Belegter Speicherplatz Belegter Speicherplatz 
ist konstant. ist variabel, 
unstrukturiert: unstrukturiert: 
Char, Integer, Real, Zeiger als Hilfsmittel. 
String, Boolean strukturiert: 
strukturiert: Datei (File), 
Feld (Array), Stapel (Stack), Schlange, 
Menge (Set), Gekettete Liste (Linked List), 
Verbund (Record). Binäre und andere Bäume, 


Rekursive Datenstrukturen. 


Einige dynamische Datentypen 
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vialer Natur" sind (so Niklaus Wirth, der Erfinder von PASCAL), 
zählt man eine Datei zu den statischen Datenstrukturen. Die 
dynamischen Datenstrukturen können vom Programmierer selbst 
durch Verknüpfung der standardmäßig angebotenen Datentypen 
konstruiert werden. Das heißt, daß alle dynamischen Strukturen 
auf einer tieferen Komponenten-Ebene irgendwo wieder statisch 
sind; Listen- (z.B. verkettete Liste) und Baumstrukturen ge- 
hören dazu. Zeiger (auch Pointer, Verweis, Referenz genannt) 
werden dabei als Hilfsmittel zur Strukturierung verwendet. Auf 
Zeiger bzw. Listen gehen wir in Abschnitt 3.13 ein. Die Rekur- 
sion als Ablauf, der sich selbst aufruft bzw. zur Ausführung 
bringt, bildet (generiert) dynamisch lokale Variable und wird 
deshalb häufig im Zusammenhang mit dynamischen Datenstrukturen 
genannt. 


1.3.2.4 Vordefinierte und benutzerdefinierte Datentypen 


Die bislang dargestellten einfachen und strukturierten Daten- 
typen sind vorde f inier t win dem Sinne, daß sie als 
Standardtypen vom DV-System bereitgestellt werden. Daneben ge- 
statten einige Programmiersprachen wie z.B. PASCAL dem Pro- 
grammierer, selbst eigene Datentypen zu definieren, die dann 
eben alsbenutzerde f in ie r t bezeichnet werden. 


Eine einfache Möglichkeit dafür besteht darin, alle Werte auf- 
zuzählen, die der Datentyp umfassen soll - deshalb der Begriff 
Aufzählungstyp. (Mo,Di,Mi,Do,Fr,Sa,So) ist ein 
solcher Aufzählungstyp für die Wochentage wie auch (6800,6830, 
6900,6907) für einige Postleitzahlbezirke. 


Eine weitere Möglichkeit bietet sich dem Benutzer dadurch, daß 
er einen Datentyp als Unterbereich z.B. eines vordefinierten 
Datentyps definiert - einen Unterbereichstyp. 
Drei Beispiele: 0..7 umfaßt als Unterbereichstyp des Datentyps 
INTEGER die 8 Ganzzahlen 0,1,2,...,7. 

"A".."zZ" umfaßt als Unterbereich des Datentyps CHAR alle Groß- 
buchstaben. 

Di..Fr umfaßt als Unterbereichstyp des obigen Aufzählungstyps 
vier Werktage. Angegeben wird also stets das kleinste und das 
größte Element des gewünschten Unterbereiches. 


Neben den Aufzählungs- und Unterbereichstypen zählen auch die 
zZeigertypen zur Kategorie der benutzerdefinierten Datentypen. 


1.3.2.5 Datentypen bei den verschiedenen Programmiersprachen 


Es hängt vom jeweiligen Programmier-System ab, mit welchen Da- 
tentypen Sie arbeiten können. 

Unstrukturierte Programmiersprachen wie BASIC lassen den Pro- 
grammierer weitgehend allein bei der Bildung von Datenstruktu- 
ren, oder anders: sie unterstützen ihn kaum. Bei BASIC fehlen 
der Verbund bzw. Record (was gerade bei der Dateiverarbeitung 
von Nachteil ist) wie auch die benutzerdefinierten Typen. 
Strukturierte Programmiersprachen stellen die oben angeführten 
Datentypen bereit. Aber auch hier gibt es Unterschiede. So ist 
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PASCAL -was. die standardmäßige Vorgabe von Datentypen angeht- 
eher sparsam, aber die wenigen Datentypen können sehr flexibel 
zum Entwurf komplexer Datenstrukturen genutzt werden. Sprachen 
wie ADA und auch MODULA 2 sind weniger sparsam ausgestattet. 


1.3.3 Programmstrukturen 


Die vier Programmstrukturen Folge, Auswahl, Wiederholung und 
Unterprogramm sind die grundlegenden Ablaufarten der Informa- 
tik überhaupt. Grundlegend in zweifacher Hinsicht: 

zum einen gelangt man beim Auseinandernehmen noch so umfang- 
reicher Programmabläufe immer auf die vier Programmstrukturen 
als Grundmuster ( Ana 1 ys e von Programmen). 

Zum anderen kann umgekehrt jeder zur Problemlösung erforderli- 
che Programmablauf durch geeignetes Anordnen dieser vier Pro- 
grammstrukturen konstruiert werden ( Synthese von Pro- 
grammen). 


1.3.3.1 Folgestrukturen 


Jedes Programm besteht aus einer Aneinanderreihung von Anwei- 
sungen an den Computer (vgl. Abschnitt 1.1.1). Besteht ein be- 
stimmtes Programm nur aus einer Folgestruktur, 
dann wird Anweisung für Anweisung wie eine Linie abgearbeitet. 
Man spricht deshalb auch vom linearen Ablauf bzw. unverzweig- 
ten Ablauf, vom Geradeaus-Ablauf oder von einer Sequenz. Das 
Beispiel zeigt ein Programm, bei dem 5 Anweisungen in Folge 
ausgeführt werden: Über Tastatur wird ein Rechnungsbetrag ein- 
gegeben, um nach der Berechnung den Skonto- und Überweisungs- 
trag als Ergebnis am Bildschirm auszugeben. Das Ablaufbeispiel 
wird als Entwurf, als Dialogprotokoll sowie als Struktogramm 
dargestellt. 


Erst Anweisung 1 ausführen, dann Anweisung 2, dann ... 


Beispiel in Entwurfsprache: Allg. Ablauf in Entwurfsprache: 
Ausgabe Fragestellung 

Eingabe RECHNUNGSBETRAG 

berechne SKCNTOBETRAG 

berechne UEBERWEISUNGSBETRAG Anweisung #4 


Ausgabe der Ergebnisse | Anweisung 5 ] 


Beispiel als Dialogprotokoll: Allg. Ablauf als Struktogramn: 





RUN rt | 
RECHNUNGSBETRAG =? 
200 
SKONTOABZUG: 6 DM RE 





UEBERWEISUNG: 194 DM 


Ablauf mit einer Folgestruktur 
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Um unabhängig von den Formalitäten der vielen Programmierspra- 
chen Programmabläufe beschreiben zu können, verwenden wir eine 
einfache Entwurfsprache (auch algorithmischer 
Entwurf oder Pseudocode genannt), die umgangssprachlich formu- 
liert wird. Im Beispiel werden die umgangssprachlichen Anwei- 
sungsworte 'Ausgabe', "Eingabe' und 'berechne' verwendet. Die 
Beschreibung von Abläufen mittels einer Entwurfsprache ist in 
der Informatik weit verbreitet. 

Dass Dialogprotokoll zum Ablaufbeispiel gibt 
den 'Dialog' zwischen Benutzer (der Werte eintippt) und Compu- 
ter (der Information ausgibt) wieder, wie er bei der Programm- 
ausführung am Bildschirm erscheint bzw. protokolliert wird. Im 
Beispiel gibt der Benutzer den Befehl RUN ein, worauf der Com- 
puter mit der Ausgabe RECHNUNGSBETRAG =? antwortet; nach der 
Benutzereingabe von 200 rechnet der Computer (im Dialogproto- 
koll nicht sichtbar) mit 3%, um dann Skonto- und Überweisungs- 
betrag in zwei Ausgabezeilen am Bildschirm anzuzeigen. 

Neben dem Entwurf und dem Dialogprotokoll ist das Programmbei- 
spiel zeichnerisch als Struktogra mm dargestellt. 


1.3.3.2 Auswahlstrukturen 


Die Auswahlstrukturen dienen dazu, aus einer 
Vielzahl von Möglichkeiten bestimmte Fälle auszuwählen: hier 
sind es die beiden Fälle 'Skontoabzug bei Bezahlung in weniger 
als 8 Tagen nach Rechnungserhalt (Bedingung TAGE<8 erfüllt)' 
sowie "Zahlung rein netto bei späterer Überweisung (Begingung 
TAGE«8 nicht erfüllt)'. Dieses Beispiel bezeichnet man deshalb 
auch ls Zweiseitige Auswahl 


Wenn Bedingung 1 erfüllt ist, dann führe Anweisung 2 aus, 
sonst führe Anweisung 3 aus, um dann gemeinsam fortzufahren. 





Beispiel in Entwurfsprache: Allg. Ablauf in Entwurfsprache: 
RS Fur RE SR URE BBBR FE a EZ MD Aeie E B 
Ausgabe der Fragestellung Anweisung 1 2 
wenn TAGE<8 wenn Bedingung 1 erfullt 
dann überweise mit Skonto dann Anweisung 2 
sonst überweise rein netto sonst Anweisung 3 
Ende-wenn Ende-wenn 
a ne 
2 Bsp. als Dialogprotokoll: Allg. Ablauf als Struktogramm: 
RUN 
ANZAHL DER TAGE =? Anweisung ] 
h - - 
SKONTOABZUG MÖGLICH Bedingung 
erfüllt? — 
RUN - Eu 8 — 
ANZAHL DER TAGE =? Anweisung 2 Anweisung 3 





14 Fall: netto Fall: Skonto 
ZAHLUNG REIN NETTO | = 


Ablauf mit einer Auswahlstruktur 
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Daneben gibt es die Einseitige Auswahl mit 
nur einem Fall und die Mehrseitige Auswahl 
bzw. Fallabfrage mit mehr als zwei Fällen. 

Auswahlstrukturen werden auch als Alternativstrukturen, Abläu- 
fe mit (Vorwärts-)Verzweigungen bzw. als Selektion bezeichnet. 


1.3.3.3 Wiederholungsstrukturen 


wWiederholungsstrukturen führen zu Pro- 
grammschleifen, die mehrmals durchlaufen werden. Im Beispiel 
wird die Anweisungsfolge 'Eingabe', 'berechne', 'berechne' und 
'Ausgabe' wiederholt durchlaufen, bis die Bedingung RECHNUNGS- 
BETRAG = 0 erfüllt ist, die über Tastatur als Signal zum Been- 





Ablauf mit einer Wiederholungsstruktur 


den der Schleife eingetippt wird. Wiederholungsstrukturen wer- 
den auch als Repetitionen und Iterationen bezeichnet. Auf die 
verschiedenen Schleifentypen wie 

- abweisende und nicht-abweisende Schleife 

- Zählerschleife 

- offene und geschlossene Schleife 
gehen wir in Abschnitt 3.1.3 an Beispielen ausführlicher ein. 
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1.3.3.4 Unterprogrammstrukturen 


Unterprogrammstrukt uren bieten sich im- 
mer dann an, wenn eine Aufgabe während eines Programmablaufes 
mehrmals benötigt wird, so z.B. die im Beispiel wiedergegebene 
Aufgabe "Runde kaufmännisch auf zwei Dezimalstellen'. Auch zur 


Führe Anweisungen Al aus, unterbreche Tätigkeit A, um Anwei- 
sungen B auszuführen, kehre zurück und fahre mit der Ausführ- 
ung der Anweisungen A2 fort (A im Haupt-, B im Unterprogramm). 


Beispiel in Entwurfsprache: 


Eingabe RECHNUNGSBETRAG 
berechne SKONTOBETRAG 
Aufruf Unterprogramm RUNDEN ——> runde BETRAG auf 2stellig 
berechne UEBERWEISUNGSBETRAG ersetze BETRAG durch den 
Ausgabe Ergebnis gerundeten BETRAG 









rufendes (Haupt-)Programm aufgerufenes Unterprogramm 


Ablauf mit Unterprogrammstruktur 


übersichtlichen Gliederung eines komplexen Programmes und zur 
Programmentwicklung im Team (jeder Mitarbeiter entwickelt ei- 
nen Teil des Programmes) werden Unterprogramme verwendet. 

Auf die möglichen Unterprogrammarten wie Prozeduren und Funk- 
tionen gehen wir in Abschnitt 3.1.4 konkret an Beispielen ein. 


1.3.3.5 Mehrere Strukturen in einem Programm 


Die meisten Programme umfassen natürlich mehrere dieser Struk- 
turen. Dabei sind zwei Anordnungsprinzipien zu unterscheiden. 
Programmstrukturen können entweder hintereinander oder aber 
geschachtelt angeordnet sein. 
- Anordnun hintereinander: 
Mit der jeweils folgenden Struktur wird erst dann begonnen, 
nachdem die gerade in Ausfühung befindliche Struktur beendet 
wurde. 
- Anordnung geschachte lt: 
Mit der äußeren Struktur kann erst fortgefahren werden,nach- 
dem die innere Struktur vollständig ausgeführt wurde. Teil- 
weises Einschachteln bzw. Überlappen von Programmstrukturen 
ist folglich nicht erlaubt. 


1.3.4 Datenstrukturen und Programmstrukturen als Software-Bausteine 


In den beiden vorangegangenen Abschnitten haben wir die wesent- 
lichen Datenstrukturen ( w a s wird verarbeitet?) sowie Pro- 
grammstrukturen ( w i e ist zu verarbeiten?) allgemein darge- 
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stellt. Diese Strukturen mit ihren unterschiedlichen Ausprä- 
gungen können als Software - Bausteine auf- 
gefaßt werde, da aus ihnen bausteinartig die zur Lösung eines 
Problems erforderlichen Abläufe gebildet werden. 


Dbateret r uk tt u r,en 
























| einfach: strukturiert: 
ICHAR, Zeichen ARRAY (Feld, Bereich) 
INTEGER, Ganzzahl RECORD, Verbund 
REAL, Dezimalzahl SET, Menge 
STRING, Text FILE, Datei 
|BOOLEAN, Logisch benutzerdefinierte Daten | 





Folge: wiederholung: 

linearer Ablauf nicht-abweisend, 
abweisend, Zählerschleif 

Auswahl: 

einseitig, zweiseitig, Unterprogramm: 

mehrseitig (Fallabfrage) Prozedur, Funktion 


Frogramımstrukturen 
Daten- und Programmstrukturen als Software-Bausteine 


Wie werden Daten(-strukturen) im Hauptspeicher abgelegt und 
verarbeitet? Wie werden Programm(-strukturen) abgespeichert? 
Wie sind Programme aufgebaut? Zu diesen Fragen kommen wir nun. 


1.3.4.1 Modell des Hauptspeichers RAM als Regalschrank 


In dem als Speicher RAM ausgebildeten Hauptspeicher befinden 
sich die zur Verarbeitung benötigten Daten und Programme. Den 
RAM können wir uns als Regalschrank mit sehr vielen Speicher- 
stellen vorstellen, in die je ein Zeichen abgelegt werden kann. 
Ein RAM mit 64 KB (vgl. Abschnitt 1.2.3.4) umfaßt genau 65536 
solcher Speicherstellen (64 * 1024), die von 0 an fortlaufend 
durchnumeriert sind, wobei die Nummern 0,1,2, ... ‚65535 die 
tatsächlichen Ad re s sen der Speicherstellen darstellen. 


Soll ein Rechnungsbetrag über 200.50 DM von Adresse 2210 oder 
von Adresse 58934 an gespeichert werden? Um diese tatsächli- 
chen Adressen müssen wir uns zumeist nicht kümmern. Wie allen 
Daten geben wir dem Rechnungsbetrag einen Namen, z.B. BETRAG, 
der dann als symbolische Adresse zur Spei- 
cherung dient. Der Computer sucht sich selbständig einen für 
BETRAG freien Speicherplatz und legt die 200.50 dorthin ab. 
wo soll das zugehörige Programm abgespeichert werden? Auch da- 
rum brauchen wir uns nicht zu kümmern. Wir geben dem Programm 
einen Namen wie z.B. RECHNUNG! „ und der Computer reserviert 
selbständig die notwendige Anzahl von Speicherstellen und be- 
stimmt dann einen geeigneten Speicherort. 

Daten wie Programme werden also über ihre Namen angesprochen. 
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Wieder zum Modell des RAM als Regalschrank: 

Einige Regale sind leer. In ihnen ist nichts gespeichert. Auf 
anderen Regalen aber befinden sich Schachteln, und zwar Daten- 
Schachteln mit Daten als Inhalt sowie Programm-Schachteln mit 
Anweisungen als Inhalt. Jede Schachtel ist mit dem von uns je- 
weils gewählten Namen beschriftet.urch Angabe dieser Namen ist 
es uns möglich, Inhalte von Schachteln zu lesen und zu ändern. 
Für die ausreichende Größe einer Schachtel (=Anzahl von Spei- 
cherstellen) sowie das passende Regal (=tatsächliche Adresse) 
sorgt der Computer selbst. 


1.3.4.2 Daten als Variablen und Konstanten 


Daten sprechen wir mit Namen an. Dies gilt für veränder- 
liche bzw. variable Daten, für Variablen, wie auch 
für feste bzw. konstante Daten, also für Konstanten. 


Das Einrichten von Daten-Schachteln bezeichnet man als Dekla- 
ration oder als Vereinbarung . Für eine Variable 
müssen wir vereinbaren, welchen Namen (z.B. den Namen BETRAG) 
und welchen Datentyp (z.B. Dezimalzahl bzw. REAL) sie haben 
soll. Mit dem Datentyp wird der Wertebereich an- 
gegeben. Den Inhalt als den Wer t der Variablen können wir 


dann später im Rahmen des jeweiligen Wertebereichs (z.B. der 
BETRAG — —_ —_  . _. SBLTRAE: / 200.50 
als Name i ern Tals’derzeitiger 
Wert bzw. Inhalt 
Dezimalzahl _—-— 





als Datentyp 


Vereinbarung in Entwurfsprache: Variable namens BETRAG vom 
ec engl nn Datentyp '"Dezimalzahl' zur 
BETRAG: Dezimalzahl bzw. REAL späteren Aufnahme von de- 

er ar ae VEIT TEL zimaligen Werten vereinbart 


Name, Datentyp und Wert kennzeichnen eine Variable 


Dezimalzahlen) beliebig verändern. Jede Variable weist somit 
die drei Komponenten Name, Datentyp (=Wertebereich) und Inhalt 
bzw. Wert (= augenblicklicher Schachtelinhalt) auf. Schachteln 
können sehr klein (wie die für den BETRAG) oder auch sehr um- 
fangreich (wie z.B. ein String-Array mit 100 Zeilen und mit 5 
Spalten für 100%5=500 Artikelmengen) sein. 


Für eine Konstante müssen wir einen Namen vereinba- 
ren (z.B. den Namen S1 für den Skontosatz) und einen konstan- 
ten Wert (z.B. 3 8). 


Die Vereinbarungen von Variablen und von Konstanten werden vom 
Programmierer im Rahmen der Programmerstellung getroffen; sie 
stehen am Anfang: der Computer muß eine Daten-Schachtel zu- 
erst einrichten, um dann mit ihr gemäß den im Programm weiter 
angegebenen Anweisungen arbeiten zu können. 


1.3 Software = Daten + Programme 35 





Name und fester Wert kennzeichnen eine Konstante 


1.3.4.3 Programm mit Vereinbarungsteil und Anweisungsteil 


Jedes Programm weist neben dem Programmnamen zwei weitere Be- 
standteile auf: den Vereinbarungsteil und den Anweisungsteil. 


Der Programmname dient zum Aufrufen des Programms im RAM als 
dem Internen Speicher wie auch auf Diskette bzw. Kassette als 
Externen Speichereinheiten. 

Im Vereinbarungs te ji 1 legt der Programmierer 
fest, welche Variablen und Konstanten einzurichten sind. In 
Abschnitt 3 werden wir sehen, daß ggf. auch selbstdefinierte 
Datentypen sowie Unterprogramme (Prozeduren und Funktionen) 
vereinbart werden können. 

In den Programmiersprachen wird unterschiedlich vereinbart. So 
muß in PASCAL der Vereinbarungsteil in jedem Fall programmiert 
werden. In BASIC können Vereinbarungen auch durch die Wahl der 
Variablen getroffen werden. 





Name, Vereinbarungsteil und Anweisungsteil als Bestandteile 
eines Jeden Programms 


Der Anweisungsteil als Folge von Anweisungen 
an der Computer enthält das eigentliche Programm. Auf die ein- 
zelnen Anweisungsarten zur Eingabe, Ausgabe, Wertzuweisung und 
Ablaufsteuerung gehen wir in Abschnitt 3.1 an Beispielen ein. 
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1.3.5 Datei und Datenbank 


Eine Datei stellt die typische Datenstruktur zur langfristigen 
Speicherung von Massendaten in der kommerziellen DV dar. Am 
Beispiel der in Abschnitt 1.3.2.2 bereits angesprochenen Kun- 
dendatei wollen wir auf die Dateiverarbeitung 
eingehen (man spricht dabei auch von Dateiverwaltung oder von 
File Handling (File für Datei)). 

Diese Kundendatei ist bewußt sehr einfach aufgebaut: 

Zu jedem der derzeit 1580 Kunden einer Handelsfirma werden die 
drei Angaben NUMMER, NAME und UMSATZ als Kundendatei auf einem 
Externspeicher abgelegt. Man sagt auch: Die Kundendatei umfaßt 
derzeit 1580 Datensätze (Kundensätze bzw. Sätze), wobei jeder 
Satz aus drei Datenfeldern als Komponenten besteht. Für diese 
Felder wiederum sind Variablen mit unterschiedlichen Datenty- 
pen vereinbart: eine Variable namens NUMMER für die Kundennun- 
mer ganzzahlig, eine Variable NAME als Text und eine Variable 
UMSATZ für den getätigten DM-Umsatz vom Datentyp Dezimalzahl. 
Die Datensätze stellen jeweils Verbunde (Records) dar. Der Da- 





4 Datensätze ausgedruckt: Datensatz als Verbund vereinbart: 
(1) 101 FREI 6500.00 KUNDSATZ: Verbund bzw. Record 
(2) 104 MAUCHER 295.60 NUMMER: Ganzzahl 
(3) 10% HILDEBRANDT 4590.05 NAME: Text 

(4) 110 AMANN 1018.75 UMSATZ: Dezimalzahl 


Ende-Verbund P 


= = = - 5 ö “=. = 


Vereinbarung der Datei: 


KUNDDATEI: Datei (File) mit Datensätzen vom Typ KUNDSATZ 





Vereinbarung und Inhalt der KUNDDATEI 


tensatz hat den Namen KUNDSATZ und die Datei heißt KUNDDATEI. 
Wie die obigen 4 Sätze zeigen, sollen die Kunden nach Kunden- 
nummern aufsteigend sortiert gespeichert sein. Mit (1),(2),... 
werden die Datensatznummern innerhalb der Datei angegeben. 


Eine Datei umfaßt mehrere Datensätze. Jeder Satz hat mehrere 
Datenfelder. Jedes Feld besteht aus mehreren Zeichen und jedes 
Zeichen wird als Byte als Kombination von 8 Bits gespeichert. 


Datei (File) .„„. namens KUNDDATEI mit 
derzeit 1580 Datensätzen. 

Datensatz (Record) „“.. mit drei Datenfeldern 
NUMMER, NAME und UMSATZ. 

Datenfeld (Field) .„.„. NAME mit 11 Zeichen 
maximal. 


Zeichen, Byte (Character) ... "R" als zweites Zeichen 
von "FREI". 

Bit (0 oder 1} Aal als Bir am Bertce 
01010010 für "R". 





Aufbau einer Datei: Datei-Satz-Feld-Zeichen-Bit 
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1.3.5.1 Zugriffsart, Speicherungsform und Verarbeitungsweise 


Auf eine Datei wird stets datensatzweise zugegriffen, sei es 
in den RAM hin e in (Lesen = E i n gabe) oder aus dem RAM 
hin aus (Schreiben = A u s gabe). Entsprechend spricht man 
vom lesenden Zugriff (vom Externspeicher in den RAM) oder vom 
schreibenden Zugriff (vom RAM auf den Externspeicher). Ist oh- 
ne weiteren Zusatz vom Zug ri f f die Rede, so meint man 
damit das Lesen von Sätzen. Zwei zugriffsarten 
sind zu unterscheiden: der direkte und der indirekte Zugriff. 


Der direkte zZzugri f£ £ läßt sich mit der Schall- 
platte vergleichen: Will man z.B. das 7. Musikstück hören,kann 
der Tonarm direkt bei diesem gewünschten Stück aufgesetzt wer- 
den. Entsprechend kann bei der Platte (Magnetplatte, Diskette) 
in der DV ein bestimmter Datensatz direkt durch Angabe seiner 
Datensatznummer als Adresse bzw. 'Hausnummer' in den RAM gele- 
sen werden. 

Der indirekte Zug ri f £f ist -wie beim Tonband- 
umständlicher: das Tonband muß z.B. zum 7. Musikstück gespult 
werden; wir können nur in der Reihenfolge zugreifen, in der 
früher einmal aufgenommen wurde. Dementsprechend muß in der DV 
Datensatz für Datensatz gelesen werden, bis z.B. der 7. Kunde 
gefunden ist. 

Wir halten fest: Beim Band (Magnetband, Kassette) kann nur in- 
direkt auf den Datensatz einer Datei zugegriffen werden, wäh- 
rend bei der Platte (Magnetplatte, Winchesterplatte, Diskette) 
auch direkt zugegriffen werden kann. Die Platte wird deshalb 
auch Direktzugriff - Speicher genannt, 
im Gegensatz zum Band als sequent ie] 1 em Speicher 
(Sequenz = Reihenfolge). 





ZUGRIFFSARTEN: 
indirekt, direkt Ä 
Hauptspeicher Externer 
RAM Speicher 
Te Diskette, 
SPEICHERUNGSFORMEN: Hard Disk, 
seriell, Kassette, 
VERARBEITUNGSWEISEN: gestreut, 
sortiert, indiziert, 
unsortiert verkettet 





Zugriff, Speicherung und Verarbeitung der Datei 


Der Begriff der SpeicherungsforRrm bezieht sich 
auf das Abspeichern bzw. Schreiben von Sätzen aus dem RAM auf 
die Datei. 

Seriell speichern heißt starr fortlaufend speichern: 
der nächste Neu-Kunde wird als nächster Kunde hinter den zuvor 
gerade geschriebenen Datensatz gespeichert. 

Gest re u t speichern heißt, daß die Sätze zufällig über 
die Plattenoberfläche hinweg streuend abgelegt werden. Zur Er- 
klärung folgendes Beispiel: In einem Betrieb seien die Kunden- 
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nummern 101,104,109,110,...,50000 vergeben. Würde man nach dem 
Verfahren "Kundennummer ergibt Datensatznummer" vorgehen, so 
würde man auf der Platte 50000 Speicherorte für die nur 1580 
Kundensätze zu reservieren haben - wahrlich verschwenderisch. 
Was tun? Man versucht, die Anzahl der Speicherorte durch die 
Wahl eines geeigneten Adreßrechungsverfahrens zu verdichten wie 
z.B. mit dem Divisions-Rest-Verfahren. Das führt dann dazu,daß 
Kunde 48236 als 237. Satz und Kunde 3973 als 1831. Satz abge- 
legt ist, daß also gestreut gespeichert ist. Der Nachteil sol- 
cher Verfahren: Für mehrere Kundennummern kann sich ein und 
dieselbe Datensatznummer ergeben. 


Nach der seriellen Speicherung und der gestreuten Speicherung 
nun zur ind i ziert en Speicherung als dritter Form. 
Zur Erklärung folgendes Beispiel: Zusätzlich zu unserer Kun- 
dendatei wird in einer Index deat ei zu jedem Namen 
die Datensatznummer gespeichert, unter der dieser Name in der 
Kundendatei zu finden ist: Kunde MAUCHER so z.B. als 2. Satz. 
Wie die Kundendatei (zur Unterscheidung Haupt- oder Datendatei 
genannt) 4 Kundensätze hat, so hat auch die Indexdatei 4 In- 
dexsätze. Dann wird diese Indexdatei nach Namen sortiert abge- 
speichert. Möchte man sich nun später alle Kunden nach Namen 
sortiert ausdrucken lassen ‚geht man wie folgt vor: 

1. Indirekter Zugriff auf den jeweils nächsten Indexsatz der 

sortierten Indexdatei. 

2. Direkter Zugriff auf den Kundensatz, dessen Datensatznunm- 

mer gerade zuvor aus der Indexdatei gelesen wurde. 

3. Mit 1. fortfahren, bis Ende der Indexdatei erreicht ist. 
Eine Indexdatei kann als Inhaltsverzeichnis aufgefaßt werden, 
das - ähnlich den Seitenangaben in einem Buchinhaltsverzeich- 
nis - die Satznummern der zugehörigen Datendatei anzeigt (in- 
dizieren bedeutet anzeigen). Zu unserer Kundendatei sind zu- 
mindest drei Indexdateien möglich: je eine für die NUMMER, für 
den NAMEn und für den UMSATZ. 


Kundendatei mit den Indexdatei für Indexdatei für 
ersten 4 Datensätzen: NAME unsortiert: NAME sortiert: 


AMANN 
FREI 11 


FREI 
MAUCHER 





01 FREI 6500.00] 
104 MAUCHER 295.60] 
109 HILDEBRANDT 4590.05 








r 
2 

HILDEBRANDT 3 HILDEBRANDT 3 
4 





110 AMANN 1018.75 AMANN | MAUCHER 2 
Hauptdäatei mit hier 3 Indexdateien mit stets 2 Datenfeldern: 
Datenfeldern NUMMER, NAME als Schlüsselfeld und SATZNUMMER 
NAME und UMSATZ. (der Hauptdatei) als Adreßfeld. 


Kundendatei als Datendatei mit zwei Indexdateien 


Das Anlegen einer Indexdatei gestattet einen schnellen Zugriff 
sowie vielseitige Verarbeitungsarten. 

Zunächst zur Geschwindigkeit: In der kaufmännischen Praxis ist 
ein Kundensatz mit z.B. 300 Zeichen viel länger als unser Bei- 
spielsatz, der Indexsatz hingegen unverändert kurz, da er ja 
nur die beiden Komponenten NAME als Schlüsselfeld und SATZNR 
als Adreßfeld umfaßt. Das Durchsuchen oder Sortieren einer In- 
dexdatei geht somit schneller vonstatten als das der zugehöri- 
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den Datendatei. Zumal die Indexdatei aufgrund ihres geringen 
Umfanges dabei komplett im Hauptspeicher gehalten werden kann, 
während die Datendatei aufgrund ihrer Größe zum Sortieren wie- 
derholt ein- und ausgelagert werden muß. 

Ein zweiter Vorteil besteht in der Vielseitigkeit: Hat man zu 
den Schlüsseln NAME, UMSATZ, PLZ, WOHNORT, VERTRETER, RABATT, 
KUNDESEIT, OFFENERPOSTEN je eine Indexdatei sortiert angelegt, 
so können die Kunden jederzeit nach diesen 8 Ordnungsbegriffen 
sortiert in einer Übersicht ausgedruckt werden. Ebenso kann 
e i n bestimmter Kunde über schnelle Suchverfahren wie etwa 
über das '"binäre Suchen' am Bildschirm angezeigt werden. 


Als vierte Speicherungsform wurde oben dieverkettete 
Speicherung genannt. Dazu folgendes Beispiel: Der Kundensatz 
wird um 2 Datenfelder erweitert, in denen Zeiger bzw. Pointer 
gespeichert sind, die auf den jeweils nächsten Kundensatz zei- 


Kunden- Kunden- Kunden- beiger Zeiger 
nummer: name: umsatz: für Name: für Umsatz: 





FREI 6500.00 
MAUCHER 295,60 


HILDEBRANDT 4590.05 
AMANN A 1018.75 


m a u | | 
De u EEE Zu 
u u u 


Kundendatei mit Verkettung über zwei Zeigerfelder 


gen. Das erste Zeigerfeld verkettet die Sätze nach Namen auf- 
steigend sortiert: Nach dem Lesen von AMANN (A für Ankeradres- 
se) verweist Zeigerfeldinhalt 1 auf FREI, der dann eingelesen 
wird; dann zeigt Zeiger 3 auf HILDEBRANDT als 3. Satz, worauf 
mit Zeiger 2 auf MAUCHER zugegriffen wird, dessen Zeiger 0 das 
Ende der Kette signalisiert. Über diese Kette 3-0-2-1 können 
die Kunden rasch alphabetisch geordnet aufgelistet werden. Die 
zweite Kette 0-4-1-3 verkettet Kunden nach deren Umsatz geord- 
net. 

Das Beispiel zeigt, daß über die verkettete Speicherung belie- 
big viele lo g is ch e Ordnungen gebildet werden können, 
ohne die Datensätze dazu ph y s is ch auf dem Externspei- 
cher umspeichern zu müssen. 


Nach den zwei Zugriffsarten und den vier Speicherungsformen 
nun zu den zwei Verarbeitungsweisen, zur 
sortierten und Zur unsortierten Verarbeitung: 

Eine Datei sortiert verarbeiten heißt, daß eine phy- 
sisch oder logisch zusammenhängende Folge von Datensätzen ver- 
arbeitet wird wie z.B. beim Auflisten des gesamten Dateiinhal- 
tes oder bei der Gehaltsabrechnung für alle Angestellten eines 
Betriebs. Wenn die Bewegungsdatei (Lagerzugänge und -abgänge) 
genauso sortiert vorliegt wie die Bestandsdatei (Artikel ins- 
gesamt), wird von einer sortierten Verarbeitung gesprochen. 

Bei der unsort ie r t en Verarbeitung werden einzelne 
Sätze einer Datei ggf. mehrmals direkt angesprochen wie z.B. 
beim Verarbeiten einzelner Kundenaufträge oder beim Auskunfts- 
erteilen über den derzeitigen Kontostand. 
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1.3.5.2 Vier Organisationsformen von Dateien 


Je nach Kombination von Zugriffsart (Eingabe eines Datensatzes 
vom Externspeicher in den Hauptspeicher RAM), Speicherungsform 
(Ausgabe vom RAM auf den Externspeicher) und Verarbeitungswei- 
se (Verarbeitung intern im Hauptspeicher) kann eine Vielzahl 
von Datei - Organisationsformen unterschieden werden. Folgende 
vier Organisationsformen werden heute am 
häufigsten genannt - wenn auch kaum einheitlich ausgelegt. 


Sequentielle Dr as, tie 47 

Indirekter Zugriff, serielle Speicherung und sortierte 
Verarbeitung bei (zumeist) sortierter Speicherungsfolge. 
Typische Band-Datei (Magnetband, Kassette). 


Din RSKIE 2 te ER, Beast, 24% 

Direkter Zugriff, oft gestreute Speicherung und unsortierte 
wie ggf. sortierte Verarbeitung. 

Typische Platten-Datei (Magnetplatte, Diskette). 
Bezeichnungen: Random-Datei, Relative Datei. 


Index - segqguentielle batei: 
Kombination von sequentieller und Direktzugriff-Datei. 
Alle Zugriffsarten, Speicherungsformen und Veräarbeitungs- 
weisen; kennzeichnend ist die indizierte Speicherung. 


Verkettete Datei; 
Indirekter Zugriff, verkettete Speicherung und sortierte 
Verarbeitung. 


Vier Organisationsformen von Dateien 


Die rein sequentiell organisierte Datei wird mit der zunehmen- 
den Verbreitung von Wechselplatte, Festplatte und Diskette im- 
mer mehr durch die Direktzugriff-Datei und die index-sequenti- 
elle Datei verdrängt. 


1.3.5.3 Grundlegende Abläufe auf Dateien 


Die Dateiverarbeitung umfaßt viele Abläufe: So müssen Daten 
zunächst einmal erfaßt bzw. computerlesbar gemacht werden, um 
sie dann auf einem Externspeicher abzulegen, später wieder zu 
suchen, abzuändern, auszudrucken, zu löschen usw. Zusammenfas- 
send können wir hierzu 11 grundlegende Abläufe zum Einrichten, 
Verwalten und Auswerten von Dateien unterscheiden. Jedes kom- 
merzielle Datei-System mit dem Anspruch auf eine universelle 
Verwendbarkeit wird diese Abläufe bereitstellen. 


In Abschnitt 1.3.1.1 wurden Bestands- und Bewegungsdaten sowie 
Stamm- und Änderungsdaten unterschieden. Entsprechend gibt es 
dem Inhalt nach vier Dateiarten: die Bestandsdatei (z.B. Arti- 
kelbestandsdatei), die Bewegungsdatei (z.B. Zu-/Abgänge von 
Artikellagerbeständen), die Stammdatei (z.B. Kundenstammdatei) 
und die Änderungsdatei (z.B. Änschriftsänderung von Kunden). 
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Grundlegende Abläufe (Algorithmen) auf Dateien 


Die elf grundlegenden Abläufe beziehen sich auf diese vier Da- 
teiarten gleichermaßen. Man spricht auch von den grundlegenden 
Datei - Algorithmen (ein Algorithmus ist eine 
Folge von Anweisungen, die in einer endlichen Schritt-Anzahl 
zur Lösung eines Problems führt). 

Zum Ablauf 'Bewegen': Bewegungen werden in der Regel gesammelt 
(gestapelt), als Bewegungsdatei gespeichert und dann z.B. zum 
Wochenende in einem Arbeitsgang verarbeitet. 

Zum Ablauf "Ändern': Sätze können tatsächlich (=physisch) oder 
nur durch eine bestimmte Markierung wie BESTAND=-99 (=logisch) 
gelöscht werden; die Inhaltsänderung kann ein oder mehrere 
Datenfelder betreffen. 

Zum Ablauf "'Sortieren': Es kann intern im RAM und/oder extern 
auf Band bzw. Platte sortiert werden. Dabei werden die Daten- 
sätze selbst oder aber nur deren Adressen (Speicherplätze) in 
eine neue Reihenfolge gebracht. 
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Zum Ablauf 'Kopieren': Beim Back-Up duplizieren wir eine Datei 
unverändert. Ebenso läßt sich eine Datei als Kopie von einer 
anderen Datei bei gleichzeitigem Ändern (Verkürzen, Erweitern 
Modifizieren) erstellen. 

Zum Ablauf "Auswählen': Hat die Datei n Sätze, so kann man ge- 
nau einen Kunden (110), mehrere vorgegebene Sätze (Kunden 101, 
104 und 110) oder eine unbestimmte Satzanzahl (alle Kunden un- 
ter 10.000 DM Umsatz) auswählen. 

zum Ablauf 'Klassifizieren': Hier wird z.B. eine Artikeldatei 
nach Lagerorten und Umschlagshäufigkeit tabellarisch ausgewer- 
tet. 

Zum Ablauf 'Verdichten': Gruppenwechsel kann einstufig (Absatz 
je Vertreter) oder zweistufig (Absatz je Vertreter u. Artikel) 
vorgenommen werden. 


1.3.5.4 Datei Öffnen, verarbeiten und schließen 


Beim Lesen, Schreiben oder Ändern einer Datei geht man immer 
in drei Schritten vor: 


1. Dateiöffnen: 
Verbindung zwischen Datei und Programm herstellen 
(Dateiname, Zugriffsart, Verbindungskanal usw.). 

2. Datei verarbeiten: 
Lesen (eingeben), schreiben (ausgeben) und/oder 
ändern (ein-/ausgeben bzw. überschreiben). 

3. Dateiischließen: 
Verbindung ordnungsgemäß beenden 
(Dateiende EOF (End of File) kennzeichnen, Directory 
(Inhaltsverzeichnis) auf Datei rückübertragen). 


Bei komplexen Datei-Algorithmen sind für diese drei Schritte 
jeweils gesonderte Unterprogramme vorgesehen, die Programm- 
vorlauf, Programmtreiber und Programmabschluß genannt werden. 


Zum Schritt 2 eine Anmerkung: Ist eine Datei auf Kassette ab- 
gespeichert, liest man nach dem Eröffnen häufig die Datei in 
einem Arbeitsgang komp let t in den Hauptspeicher, um 
sie dort z.B. als Array (Feld, Bereich, Tabelle) verarbeiten 
zu können. Erst unmittelbar vor dem Schließen wird die aktua- 
lisierte Datei dann - wiederum komplett - auf die Kassette zu- 
rückgeschrieben. Man bezeichnet dies als dateiweisen Datenver- 
kehr. 

Ist die Datei größer als der im RAM intern verfügbare Spei- 
cherplatz, dann ist dieses Vorgehen nicht möglich. Als Gegen- 
stück kann man mit Schritt 2 je einen Datensatz einzeln 
in den RAM übertragen und umgekehrt (datensatzweiser Datenver- 
kehr). 

Zwischen diesen beiden Extremen - Datenverkehr dateiweise oder 
datensatzweise - gibt es natürlich zahlreiche Abstufungen. 


1.3.5.5 Eine oder mehrere Dateien verarbeiten 
In der kaufmännischen Praxis wird man nur selten eine Da- 


tei einzeln verarbeiten. Vielmehr sind zumeist mehrere 
Dateien in ein System eingebunden; man spricht dann häufig von 
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einer Dateiverkerttvurng. Dazu ein Beispiel: In 
einer Lagerverwaltung sind die "Artikelstammdatei', 'Bestands- 
datei', 'Bestelldatei (Einkauf)' und "Auftragsdatei (Verkauf)' 
verkettet, um von einem Programm(-paket) verwaltet zu werden; 
Datenverwaltungs - System ist die oft 
verwendete Bezeichnung hierfür. 

Wird nicht nur die Aufgabe der Lagerverwaltung gelöst, sondern 
werden sämtliche betrieblichen Aufgaben in einem Datei-System 
eingebunden, dann spricht man oft von integrierter 
Datenverarbeitung. 


1.3.5.6 Datenbank 


Bei isolierter Verarbeitung einzelner Dateien wie auch bei der 
Dateiverkettung ist nicht zu vermeiden, daß ein Datum mehrfach 
in verschiedenen Dateien gespeichert ist; man spricht von der 
Datenredundeanz . So kann z.B. ein Kunde samt Kun- 
denanschrift in der Kundenstammdatei, der Offene-Posten-Datei 
und der Weihnachtsgeschenkedatei dreifach gespeichert sein. Um 
dies zu vermeiden, faßt man sämtliche Daten in einer ge- 
meinsamen Datenbasis zusammen, die Datenbank genannt 
wird. Eine solche Datenbank kann - für sich alleine genommen - 
ebenfalls als Verkettung von Dateien angesehen werden. Daß we- 
sentlich neue dabei ist, daß auf alle Elemente der Datenbank 
über ein Datenbankmanagementsystem 
(DBMS) zentral zugegriffen wird. Das DBMS besteht aus meh- 
reren Systemprogrammen zur Durchführung von Aufgaben wie dem 
Ändern von Daten der Datenbank, dem gleichzeitigen Zugriff 
mehrerer Benutzer, dem Abfragen von Daten, dem Überprüfen der 
Zugriffsberechtigung usw.. 


Datenbank-System (DBS) 


Datenbank - | Datenbank 
management- =. .CDB) 


system (DBMS5) 
Benutzer 
mit Sprachen - mit Dateien 
wie: wie: 


DDL, | Artikelstamm, Gehalt, 
DML | Kunden, Rechnung, 
Lager, Bestellungen 





Das Datenbank-System besteht aus Datenbank und DBMS 


Mit dem DBMS werden dem Benutzer unter anderem zwei sprachli- 
che Hilfsmittel zur Verfügung gestellt: 

Zum einen die Daten-Definitions-Sprache DDL (Data Definition 
Language) zum Aufbau und zur Pflege der Datenbank. Mit der DDL 


Ma 1 Computer allgemein 


werden z.B. die Datensätze definiert (Name, Anzahl, Datentyp, 
Länge der Satzkomponenten). Sie richtet sich mehr an den Pro- 
grammierer bzw. an den Datenbankverwalter. 

Zum anderen eine Daten-Manipulations-Sprache DML (Data Manipu- 
lation Language) zur eigentlichen Behandlung der Daten. Diese 
DML richtet sich mehr an den Sachbearbeiter, der ein Abfrage 
wie "Drucke eine Übersicht aller Kunden aus, die offene Rech- 
nungen über DM 5000.- zu begleichen haben'laufen läßt. Die DML 
wird auch als Abfragesprache bzw. Query-Language bezeichnet. 
Datenbank-Sprachen weisen wie Programmiersprachen zumeist eng- 
lische Anweisungsworte auf wie etwa FIND zur Suchanfrage, READ 
zum Lesen, WRITE zum Schreiben, DELETE zum Entfernen, INSERT 
zum Einfügen von Datensätzen. 


Das herkömmliche Date i -Syst em unterscheidet sich 
in zumindest 3 Punkten vom Datenbank -Systenm: 


- Redundanzfreiheit: 
In der Datenbank werden die Daten möglichst redundanzfrei 
abgelegt, d.h. nicht mehrfach gespeichert. 

- Vielfache Verwendbarkeit: 
In der Datenbank werden die Daten vielfach verwendbar abge- 
legt, um vielen Benutzern einen möglichst einfachen Direkt- 
zugriff zu gestatten. 

- Datenunabhängigkeit: 
Die Programme bzw. Zugriffspfade arbeiten datenunabhängig in 
dem Sinne, daß bei der Änderung der Daten keine Änderung des 
Programms notwendig wird. 


Zwei grundlegende Datenbank-Systeme sind zu unterscheiden: das 
strukturierte und das unstrukturierte Datenbank-System. Struk- 
tieriert bedeutet, daß in der Datenbank selbst Information zum 
Verweisen auf weitere Information abgespeichert ist; damit muß 
bei Anfragen stets entlang der vorgegebenen Pfade vorgegangen 
werden. Im Gegensatz dazu gibt es bei der unstrukturierten Da- 
tenbank keine vordefinierten Zugriffspfade; damit verlangsamt 
sich der Zugriff, gleichzeitig jedoch hat man unbegrenzte Mög- 
lichkeiten, Daten nach bestimmten Suchkriterien abzufragen. 


Datenbank - System (DBS5) 
STRUKTURIERT: 
Suchbegriffe, Zugriffspfade 


UNSTRUKRTURIERT: 
Verknüpfung der Information 


festgelegt und gespeichert. 


- Hierarchisches DBS: Daten 
baumartig verkettet. 


- Netzwerk-Modell (CODASYL): 


Netz von Zugriffspfaden. 


erst im Moment der Abfrage. 


Invertierte Dateien: Zugriff 


über Index-Listen. 


Relationen-Modell: Anordnung 


der Daten in Tabellenform. 


Strukturiertes und unstrukturiertes Datenbank-System 


Beim Netzwerk-Modell gemäß dem CODASYL-Ausschuß (COnference of 
DAta SYstem Language in den USA im Jahre 1971) sind die in der 
Datenbank abgelegten Daten in Datentypen (Item Types) sowie in 


1.3 Software = Daten + Programme 45 


Datensatztypen (Record Types) zu gliedern, wobei zwischen den 
verschiedenen Datensatz-Typen sogenannte Beziehungstypen (Set 
Types) definiert werden. 

Beider relationalen Datenbank als Ge- 
genstück zum Netzwerk-Modell werden nur Datensätze im herkömm- 
lichen Sinne unterschieden, wobei die einzelnen Datensatzkonm- 
ponenten bzw. Datenfelder in Beziehung zueinander stehen wie 
die Zeilen und Spalten einer Matrix (Tabelle bzw. zweidimen- 
sionaler Array). Dazu als Beispiel unsere Kundendatei von Ab- 
schnitt 1.3.5: 


101 FREI 6500.00 Matrix mit n Zeilen und 3 Spalten. 
104 MAUCHER 295.60 Jeder Zeile entspricht ein Daten- 
109 HILDEBRANDT 4590.05 satz, jeder Spalte ein Datenfeld. 
110 AMANN 1018.75 Zugriffsbeispiel: Matrix{(2,3) er- 
oo. 0..% ... gibt 295.60 (2. Zeile, 3. Spalte). 


Das Relationen-Modell ist weit anschaulicher als das Netzwerk- 
Modell. Komplexe Datenstrukturen allerdings lassen sich in ei- 
ner "flachen Matrix" nur schwer darstellen. 


Ursprünglich lag die Aufgabe eines Datenbank-Systems in der 
Informationswiedergewinnung (= Information Retrieval) bzw. in 
der Auskunftserteilung. Zunehmend werden kommerzielle Daten- 
bank-Systeme angeboten, die darüberhinaus andere Aufgaben wie 
das Rechnen (sogenannte "rechnende Datenbanken') oder z.B. die 
Textverarbeitung übernehmen. Ä 

"„.. eine dedizierte Datenbank - Maschine _ 
die mit einem Host-Computer günstiges Datenmanagement bietet". 
Was beinhaltet eine solche Anzeige? 

Eine Datenbank-Maschine ist kein Allzweck-Computer, sondern 
ein Automat, dessen Hardware ausschließlich auf die Verwaltung 
einer Datenbank ausgerichtet bzw. dediziert ist. Darüberhinaus 
gibt es kein "'normales' Betriebssystem, sondern nur ein Soft- 
warepaket, das immer im Speicher resident ist und dabei sänmt- 
liche Funktionen einer relationalen Datenbank übernimmt. Damit 
sind wir bei der Begründung: Relationale Datenbanken benötigen 
viel Speicherplatz sowie CPU-Zeit, der Personalcomputer wird 
allzuleicht überlastet. Deshalb die Hinwendung von der "Soft- 
ware-Datenbank" zur "Hardware-Datenbank-Maschine", die an den 
Personalcomputer als Host bzw. Wirt und Gastgeber (vgl. auch 
Abschnitt 1.3.6.5) angeschlossen wird. Diese Lösung hat die 
folgenden Vorteile: Der PC als Host wird durch die Datenbank 
belastet; die Größe der Datenbank ist unabhängig von der Größe 
des Personalcomputers. 


1.3.6 System-Software (Betriebssystem) 


Das Betriebssystem mit seinen Steuer-, Dienst- und Übersetzer- 
programmen (vgl. Abschnitt 1.3.1.2) dient als Mittler zwischen 
dem Anwender(-programm) und dem Computerkern (Hardware). 
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1.3.6.1 Betriebssystem als Firmware (ROM) oder als Software 


Hinsichtlich der Speicherung des Betriebssystems gibt es zwei 
extreme Möglichkeiten, die gerade für Personalcomputer von In- 
teresse sind: 

Auf der einen Seite ist das Betriebssystem fest in ROMs unter- 
gebracht (ROM als Festspeicher enthält die Systemprogramme als 
Firmware) und steht beim Einschalten des Computers unmittelbar 
zur Verfügung. Diese Möglichkeit ist vorteilhaft, wenn man nur 
mit einer einzigen Programmiersprache arbeiten möchte. "Reine 
BASIC-Maschinen' z.B. sind oft so aufgebaut und sehr einfach 
zu bedienen. 

Auf der anderen Seite ist das Betriebssystem als Software auf 
einem Externspeicher (Diskette, Hard Disk) gespeichert und muß 
beim Einschalten des Computers vom Benutzer in den Internspei- 
cher geladen werden. Diese umständlichere Art der Bedienung 
(Handling) hat für den Benutzer jedoch den Vorteil, daß leicht 
z.B. auf eine andere Programmiersprache wie COBOL, PASCAL oder 
FORTH umgerüstet werden kann: er muß nur das zugehörige Über- 
setzerprogramm für COBOL, PASCAL bzw. FORTH von einer Diskette 
in den RAM laden. 
Personalcomputer mit mehreren Betriebssystemen (z.B. MS-DOS, 
CP/M und UCSD) haben diese stets als Software gespeichert. 


Zwischen der reinen Firmware-Lösung (Betriebssystem im ROM ) 
und der reinen Software-Lösung (Betriebssystem auf Diskette) 
als Extremen gibt es natürlich Zwischenlösungen. So kann beim 
Einschalten des Computers z.B. die Sprache BASIC aus dem ROM 
automatisch für den Benutzer mit der Möglichkeit zur Verfügung 
gestellt werden, später aus BASIC "auszusteigen',um ein anderes 
Betriebssystem bzw. Sprachmittel softwaremäßig zu laden. 


1.3.6.2 Beispiel: Betriebssystem unterstützt Computer-Start 
Die Funktion des Betriebssystems läßt gut sich am Beispiel des 


Startens eines Personalcomputers veranschaulichen. Man geht in 
drei Schritten vor. 


Internspeicher (RAM): Externspeicher (Diskette): 


| Startprogramm aus ROM | Disketten-Directory 


| Disketten-Directory BASIC-Interpreter 


| Sonstiges Sonstige 5Systemprogramme 
| Betriebssystem des Betriebssystems 


frei für Benutzer Anwenderprogramme A,B,..,5 


frei für Benutzer 





Schritt (1): "Computer einschalten' und Betriebssystem 
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Schritt (1) : Gerät anschalten. Aus einem ROM als Nur- 
Lese-Speicher wird automatisch ein Startprogramm zur Ureingabe 
in den Hauptspeicher gebracht. Dieses lädt die Datei-Directory 
(Verzeichnis der auf Diskette gespeicherten Dateien sowie Pro- 
gramme) ebenfalls in den RAM wie auch das Betriebssystem mit 
seinen Programmen. Das Betriebssystem zeigt nun dem Benutzer am 
Bildschirm durch ein Zeichen an, daß der Computer betriebsbe- 
reit ist. Der Benutzer befindet sich auf der Betriebssystem- 
Ebene (System Mode). 


Sch ri t t (2) : Der Benutzer hat sich entschieden, BASIC 
zu laden und tippt den entsprechenden Betriebssystem-Befehl 
ein. Das Betriebssystem prüft in der Disketten-Directory nach, 
ob auf der Diskette das BASIC-Übersetzerprogramm auch vorhan- 
den ist und lädt es zusätzlich in den RAM. Dies entspricht der 
oben angesprochenen Software-Lösung; bei der Firmware-Lösung 
würde Schritt (2) automatisch als Teil einer starren Befehls- 
folge nach dem Einschalten ablaufen. 


Internspeicher (RAM): Internspeicher (RAM): 


Startprogramm aus ROM| 


Disketten-Directory 


Startprogramm aus ROM 


Disketten-Directory 
Sonstige 


Betriebssystem 


Sonstiges 
Betriebssystem 


BASIC-Interpreter 


BASIC-Interpreter 


Anwenderprogramm A 
frei für Benutzer Den a Er a 


frei für Benutzer 





(2) "BASIC laden' (links) und (3) 'Prog. A laden' (rechts) 


Schr it t (3) : Der Benutzer kann sich jetzt ein auf der 
Diskette enthaltenes Anwenderprogramm in den RAM laden wie im 
Beispiel das Programm A. Das Übersetzerprogramm (ein Interpre- 
ter, wie im folgenden Abschnitt zu zeigen) ruft zum Laden das 
Betriebssystem auf, welches nach dem Ladevorgang wiederum die 
Kontrolle an das Übersetzerprogramm zurückgibt. 

Anschließend kann der Benutzer in einem Schritt (4) das Anwen- 
derprogramm A ausführen lassen. 


1.3.6.3 Übersetzerprogramme 


Ein Computer versteht soviele Programmiersprachen (=Fremdspra- 
chen) wie Übersetzerprogramme vorhanden sind. Die Übersetzer- 
programme wandeln Programmiersprache in die Maschinensprache 
(=Muttersprache des Computers) um. 

Es gibt maschinenorientiert e Programmier- 
sprachen, bei denen als "1-zu-1-Sprachen" dann meist 1 Fremd- 
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sprachenanweisung zu 1 Maschinenbefehl führt; sie heißen auch 
Assembler(-sprachen). 

Das Gegenstück sind die problemorientierten 
Programmiersprachen als "1-zu-mehr-Sprachen". Bei ihnen wird 
I Fremdsprachenanweisung in mehrere Maschinensprachenbefehle 
übersetzt wird. Die zugehörigen Übersetzerprogramme sind ent- 
weder Compiler oder aber Interpreter. 


Programmiersprachen als Fremdsprachen für Computer 


RA HRG EEE EEE Te EEE: 


maschinenorientierte problemorientierte 
1-zu-1-Sprachen 1-zu-mehr-Sprachen 
Quellenprogramm Quellenprogramm Quellenprogramm 
ASSEMBLER COMPILER INTERPRETER 
übersetzt übersetzt übersetzt 
programmweise programmweise anweisungsweise 
Maschinenprogramm Maschinenprogramm Maschinenbefehl 
als Objekt als Objekt als Objekt 


Maschinen- und problemorientierte Programmiersprachen 


Jeder Computer hat seine eigene maschinenorien- 
t ijer te Programmiersprache, die - obwohl von Computer zu 
Computer z.T. verschieden aufgebaut - stets Assembler 
heißt. Das in Assembler geschriebene Programm (auch Quellen- 
programm, Quellcode oder Source-Listing genannt) kann der Com- 
puter noch nicht verstehen. Ein Übersetzerprogramm, das (ver- 
wirrend? ) ebenfalls Assembler genannt wird, übersetzt nun das 
Quellenprogramm in die für die CPU verständliche Maschinen- 
sprache als Objektprogramm. Das eigentliche Maschinenprogramm 
steht als Abfolge hexadezimaler Bytes computerverständlich im 
Internspeicher; da es für uns nur schwer lesbar ist, wird es 
vom Assembler zur Kontrolle als Assembler-Listing ausgegeben. 


Interpreter und Compiler als Übersetzer- 
programme arbeiten analog zum menschlichen Sprachübersetzer 
wie folgt: 

Ein Interpreter (to interprete = auslegen) arbeitet wie ein 
Simultan-Dolmetscher: Der Dolmetscher übersetzt Satz für Satz, 
um das Ergebnis sofort mitzuteilen. Ein Interpreter übersetzt 
Anweisung für Anweisung, um jede Anweisung sofort auszuführen. 
Ein Compiler (to compile = zusammensetzen) hingegen arbeitet 
wie ein 'normaler' Fremdsprachenübersetzer: Dieser übersetzt 
das gesamte Fremdsprachenschriftstück zu einem bestimmten Ter- 
min. Entsprechend übersetzt ein Compiler das gesamte Anwender- 
programm komplett in einem Arbeitsgang: Das in einer sogenann- 
ten Hochsprache verfaßte Programm wird in einem gesonderten 
Compilierungslauf in ein _lauffähiges Maschinenprogramm über- 
setzt. 

Die Vorteile eines compilierenden Systems (z.B. Objektprogramm 
in 0/1-Form ablauffähig auf Externspeicher abgelegt, Programm- 
ausführung sehr schnell) und seine Nachteile (z.B.eine Feh- 
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lerkorrektur erfordert die komplette Neuübersetzung, Speicher- 
bedarf für Quelle, Übersetzer und Objekt sehr groß) sind stets 
abzuwägen. | 

Günstig ist: Programmentwicklung sowie Programmtest mit einem 
Interpreter und dann abschließende Compilierung des Programms. 


Gerade bei Personalcomputern lassen sich Interpreter und Com- 
piler kaum mehr streng trennen. So gibt es compilierende In- 
terpreter und interpretierende Compiler. 

Zum "compilierenden Interpreter' ein Beispiel: 

Die große Softwarefirma Microsoft hat solche Zwischenlösungen 
als BASIC-Interpreter z.B. für Apple, CBM, TRS-80 entwickelt. 
Dabei werden die BASIC-Zeilen beim Eintippen -für den Benutzer 
unbemerkt- in einen sogenannten Zwischencode übersetzt (PRINT 
wird z.B. als hexadezimal BA bzw. dezimal 186 zwischengespei- 
chert, nicht aber in fünf ASCII-Zeichen bzw. Bytes als PRINT). 


Zum 'interpretierenden Compiler' ebenfalls ein Beispiel: 

Der unter dem Betriebssystem UCSD laufende PASCAL-Compiler 
übersetzt den Quellcode in e i n e m getrennten Übersetzungs- 
lauf in einen Zwischencode (P-Code genannt für Pseudo-Code), 
der dann zur Ausführungszeit durch einen Interpreter weiter 
übersetzt wird. 





Interpreter und Compiler mit Zwischenlösungen 
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1.3.6.4 Programmiersprachen 


Es gibt mehrere Hundert Programmiersprachen. Die wichtigsten 
Sprachen werden in Stichworten beschrieben: 


ADA: Diese nach Lady Ada Augusta benannte Sprache wurde 1980 
vom US - Verteidigungsministerium herausgebracht (wie früher 
COBOL) und wird als Universalsprache eine vielleicht ebenso 
große Verbreitung finden wie COBOL. ADA-Subsets laufen bereits 
auf Personalcomputern. 


ALGOL 60: Diese '"ALGOrithmic Language' gibt es seit 1960. Sie 
wird vornehmlich im Hochschulbereich eingesetzt. 


APL: "A Programming Language' gilt als eines der mächtigsten 
und knappsten Sprachmittel. Berühmt sind die APL-Einzeiler mit 
ihren Kurz-Operatoren (griechische Symbolik). Auf Personalcom- 
putern mit 16-Bit-Prozessoren läuft APL stets als Interpreter. 


ASSEMBLER: Die maschinenorientierten Assembler-Sprachen (vgl. 
Abschnitt 1.3.6.3) gehören eigentlich nicht in diese Übersicht 
von Hochsprachen bzw. 1-zu-Mehr-Sprachen. Makros als Gruppen 
von Einzelbefehlen jedoch machen das maschinennahe Arbeiten in 
Assembler etwas weniger mühsam. 


BASIC: Für diese auf Personalcomputern am weitesten verbrei- 
tete Sprache (Beginners All Purpose Symbolic Instruction Code) 
gibt es fast so viele Dialekte wie Computertypen. Am weitesten 
ist das "Microsoft-BASIC" verbreitet. BASIC gibt es sowohl als 
compilierende Sprache (z.B. C-BASIC) wie auch als Interpreter. 
BASIC gehört zu den unstrukturierten Sprachen. 


C: In der Sprache C ist das Betriebssystem UNIX geschrieben. 
Es kann PASCAL-ähnlich strukturiert programmiert werden, dabei 
werden aber weniger Datentypen und mehr Operatoren (etwa wie 
in APL) bereitgestellt. Gut in C: Zeiger (Pointer) zur Adreß- 
verkettung. Die C-Compiler sind leider nicht standardisiert. 


COBOL: Die "Common Business Oriented Language"! gibt es bereits 
seit 1959. COBOL ist d i e kommerzielle Programmiersprache, 
genormt, äußerst umfangreich. Ungefähr 50% aller US-Software 
ist in COBOL geschrieben. Zitat: "COBOL ist nicht gut, aber es 
gibt viele Programmierer, die diese Sprache gut beherrschen". 


ELAN: Diese Ende der 70er Jahre in Berlin entwickelte Sprache 
unterstützt das strukturierte Programmieren und wird im Schul- 
bereich in Konkurrenz zu PASCAL eingesetzt. 


FORTH: Dies ist eine interpretierende Sprache, die jedoch zu- 
nächst den FORTH-Text in einen Zwischencode übersetzt (siehe 
Abschnitt 1.3.6.3). FORTH gibt es auch für kleinere Computer. 


FORTRAN: Der 'FORmula TRANslator' entstand 1950 und gilt als 
die wichtigste Hochsprache zur Lösung math/naturwissenschaft- 
licher Probleme. Wie COBOL ist FORTRAN eine typische Großcom- 
putersprache. BASIC ist ein FORTRAN-Abkömmling. 
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LISP: Der LISP-Interpreter wird insbesonders von Wissenschaft- 
lern verwendet, die sich mit der 'Künstlichen Intelligenz' be- 
schäftigen (Nachahmung des menschl. Gehirns durch die CPU, Ab- 
schnitt 1.1.3). Eine LISP-Variable hat als 'Atom' neben Namen 
und Wert vom Programmierer frei zu vereinbarende Merkmale, die 
als Liste geführt werden (deshalb: LISP für LISt Processor). 


LOGO: "Anders als die anderen Sprachen". Diese Aussage trifft 
für APL (im Hinblick auf die komprimierte Problembeschreibung 
über mächtige Operatoren) sowie für LOGO (im Hinblick auf die 
kindgerechte Schildkrötengrafik) zu. Bei den "Turtle Graphics" 
kann die am Bildschirm kriechende Schildkröte zum Zeichnen von 
Bildern gesteuert werden. LOGO-Interpreter kommen mit wenig 
Platz aus und sind zunehmend für Personalcomputer erhältlich. 


MODULA 2: Diese Sprache wurde von Niklaus Wirth als Nachfol- 
gesprache zu PASCAL entwickelt. Besondere Merkmale: Typische 
'Hochsprachen-Anwendungen' sind ebenso möglich wie maschinen- 
nahe Programmierung; ausgereifte Modularisierung (Module als 
Bausteine -anders als in PASCAL- separat speicherbar in Modul- 
Bibliothek); Compiler kann Maschinencode erzeugen zwecks Ein- 
brennen in PROMs (damit Nutzung als Entwicklungssprache für 
Mikrocomputerprodukte). Es wird erwartet, daß sich MODULA 2 
durch ihre Kompaktheit als Alternative zu ADA behaupten wird. 


PASCAL: "PASCAL erzieht zum klaren Programmieren" - aus diesem 
Grunde halten gerade die Lehrer so viel von dieser von Niklaus 
Wirth 1972 erstmalig beschriebenen Sprache. PASCAL ist nach 
dem Mathematiker und Philosophen Blaise Pascal (1623-1662) be- 
nannt und gilt als d i e Sprache für das strukturierte Pro- 
grammieren. Leider ist nur das ursprüngliche Wirth'sche PASCAL 
standardisiert, nicht aber die später notwendig gewordenen Er- 
weiterungen (wie Grafik-, Text- und Dateiverarbeitung; Wirth 
beschrieb so z.B. nur die sequentielle Banddatei). So sind die 
sehr zahlreichen auch für Personalcomputer verfügbaren PASCAL- 
Compiler oft nicht kompatibel: etwa ALCOR-PASCAL, JRT-PASCAL, 
PASCAL/MZ+, PASCAL/Z, ProPASCAL, TCL-PASCAL, SCHTAC-PASCAL 
und UCSD-PASCAL, wobei sich letzteres fast zum Ersatz-Standard 
entwickelt hat. 


PILOT: Diese 'Programmed Inquiry Learning or Teaching' ist für 
Personalcomputer als BASIC-Ersatz für Lehr-/Lernzwecke ent- 
wickelt worden. PILOT arbeitet ausschließlich interpretierend. 
PILOT wird eingesetzt im Rahmen des Computer-unterstützten Un- 
terrichts (CUU) bzw. der Computer Aided Instruction (CAI). 


PL/1: Die "Programming Language 1' wurde von der IBM für Groß- 
computer entwickelt und umfaßt die Sprachelemente von COBOL und 
FORTRAN zusammen - aber modern strukturiert. Wertmäßig dürfte 
die in PL/1 geschriebene Software nach der COBOL-Software den 
zweiten Platz einnehmen. Für PCs gibt es PL/1 (noch?) nicht. 


Diese Auswahl kann keinesfalls vollständig sein. Die Liste von 
Programmiersprachen ließe sich fortsetzen: BCPL, COMAL, CORAL, 
DIBOL, EUCLID, MUMPS, PEARL, PL/M, PROLOG, RPG II, SIMULA 67, 
SNOBOL, STOIC, ... 

Abschließend: Vermutlich werden in 10 Jahren Programmierspra- 
chen überwiegen, die heute noch nicht einmal entworfen sind. 
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1.3.6.5 Herstellerabhängige und unabhängige Betriebssysteme 


Die Abkürzung DOS steht für 'Disk Operating System'. Es ist 
ein Systemprogramm, das alle mit der Diskette verbundenen Ein- 
und Ausgaben kontrolliert. Die Bezeichnung DOS findet sich als 
Namensbestandteil zahlreicher Betriebssysteme. 

Das DOS für den Apple wie auch das TRS-DOS der TRS-80-Model- 
le von Tandy sind Beispiele für Betriebssysteme, welche vom 
Personalcomputer-Hersteller speziell auf das eigene Gerät hin 
zugeschnitten wurden. Herstellerabhängige 
Systeme findet man vornehmlich bei kleineren Personalcomputern 
mit 8-Bit-Mikroprozessoren. 


Personalcomputer der 16-Bit-Klasse und 32-Bit-Klasse arbeiten 
überwiegend mit herstellerunabhängigen 
Betriebssystemen, die von Software-Produzenten entwickelt wur- 
den. So mit CP/M und MS-DOS der beiden Software-Giganten Digi- 
tal Research und Microsoft, mit UCSD der Universität von San 
Diego in Californien, mit UNIX, XENIX, OASIS, ..... 

wie kam es dazu? Früher baute jeder Hersteller sein eigenes 
Betriebssystem, um es mit dem Computer als Einheit anzubieten. 
Um das Betriebssystem herum wurde ein großer Schleier gelegt - 
ein Übernehmen oder Anpassen an einen anderen Computer war so- 
mit unmöglich. Dies änderte sich erst, als die Software-Firma 
Digital Research ihr "Control Program for Microcomputers', ge- 
nannt CP/M, als herstellerunabhängiges Software-Produkt anbot: 
mit einer exakten Beschreibung der Verbindung (Schnittstellen) 
des Betriebssystems zur Computerhardware. Nun begannen immer 
mehr Hersteller, CP/M-fähige Computer zu produzieren. Mit der 
raschen Verbreitung von CP/M nahmen solche Programme zu, die 
CP/M-verträglich waren. Ursprünglich wurde CP/M für den Mikro- 
prozesor 8080 und später für den Z-80-Prozessor eingesetzt, 
deshalb die Bezeichnung CP/M-80. 

Die Variante CP/M-86 wurde für den 8086-Prozessor entwickelt. 
Über das BIOS (Basic Input-Output System) als dem adaptierba- 
ren Teil des CP/M läßt sich dieses prozessorabhängige System 
an Computer anpassen, die eine CPU haben, welche z.B. den Code 
des Intel 8088 verarbeiten. 


Betriebssystem 

herstellerabhängig: Berarallernnaneengigt 

Apple- -DOS für Apple 

TRS-DOS für Tandy 
Ge prozessorunabhängig: 
CP/M- 80 für 8080, 280 UCSD-P - System 
CP/M-86 für 8086 
Implementierung über Implementierung über 
BIOS P-Code-Interpreter 


Herstellerabhängige und -unabhängige Betriebssysteme 
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1.3.6.6 Einige Betriebssysteme kurzgefaßt 


Auf die Betriebssysteme CP/M, MS-DOS, UNIX und USCD wollen wir 
kurz eingehen. 


Zunächst zu CP/M von Digital-Research: 

CP/M war das erste Betriebssystem für PCs, wurde seit 1974 an- 
geboten und entwickelte sich schon bald zum Quasi-Standard für 
8-Bit-Computer mit den CPUs 8080, 8085 und 2-80. Im Hinblick 
an, die 80er-CPUs bezeichnet man dieses Betriebssystem oft als 
CP/M-80. 

Für 16-Bit-Computer mit der CPU 8086 von Intel entwickelte Di- 
gital Research das Betriebssystem CP/M-86. Da CP/M-80 zum Teil 
in Assembler geschrieben ist, stellt CP/M-86 eine Neuentwick- 
lung dar (die CPU 8086 arbeitet in einem anderen Code als die 
CPUs der 80er Serie). Deshalb auch die Probleme bei der Kompa- 
tibilität zwischen CP/M-80 und CP/M-86. 

Für den Multi-User-Betrieb bietet Digital Research die Systeme 
MP/M-80 sowie MP/M-86 (Multiprogramming Monitor for Microcom- 
puter) an. 

Das Betriebssystem CONCURRENT CP/M wurde für den Single-User- 
Betrieb unter Multi-Tasking entworfen: mehrere Aufgaben können 
als Tasks gleichzeitig auf e ine m PC bearbeitet werden. 
MP/M sowie CONCURRENT CP/M erweitern den Leistungsumfang des 
CP/M um die jeweiligen Funktionen des Multi-Using bzw. Multi- 
Tasking. 

Das Betriebssystem PERSONAL CP/M läßt sich in einem ROM unter- 
bringen und eignet sich deswegen auch für PCs ohne Disketten- 
laufwerk. PERSONAL CP/M wurde eigens für kleinere PCs entwik- 
kelt und unterstützt sowohl 8-Bit-CPUs als auch 16-Bit-CPUs. 


Zu MS-DOS von Microsoft: 

Als Konkurrenprodukt zu CP/M-86 von Digital Research brachte 
die Softwarefirma Microsoft das Betriebssystem MS-DOS heraus. 
IBM wählte für seinen PC als Betriebssystem MS-DOS, und zwar 
in einer Version, die den Namen PC-DOS erhielt und hardware- 
abhängiger ist als MS-DOS selbst. Durch die Wahl dieses Be- 
triebssystems wurde MS-DOS sehr populär. . 

Für den "PC jr." von IBM wurde das Betriebssystem MS-DOS 2,1 
entwickelt. In seiner Funktionalität steht es auf einer Stufe 
mit MS-DOS 2.0 oder MS-DOS 2.11, es kann aber ohne Disketten- 
laufwerk eingesetzt werden (viele Teile von MS-DOS 2.1 sind im 
ROM untergebracht und nicht im RAM). 

Die Version MS-DOS 3.0 ist für Multi-Using und für Multi-Tas- 
king konzipiert. 


Zum Betriebssystem UNIX: 

Im Gegensatz zu CP/M sowie MS-DOS ist das Betriebssystem UNIX 
nicht in Assembler, sondern fast vollständig in der Sprache C 
geschrieben. Damit ist UNIX auf alle PCs übertragbar, die über 
einen C-Compiler verfügen. UNIX wurde von Wissenschaftlern für 
Wissenschaftler geschrieben - entsprechend profihaft wie kom- 
pliziert ist seine Benutzung. Deshalb wurden viele von UNIX 
abgeleitete und leichter bedienbare Betriebssysteme entwickelt 
wie ZEUS von Zilog, GENIUS von National, REGULUS von Motorola 
und XENIX von Microsoft. 

Das bekannteste UNIX-Derivat ist XENIX. Es unterstützt Multi- 
Using wie auch Multi-Tasking. 
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Zum Betriebssystem UCSD: 

UCSD ist die Abkürzung für University of California San Diego. 

Früher stand UCSD für das Programmiersprachsystem UCSD-Pascal, 

während es heute als umfassendes Betriebssystem mehrere Über- 

setzer anbietet wie BASIC-Compiler, FORTRAN 77-Compiler, LISP- 

Interpreter, MODULA-2-Compiler und natürlich PASCAL-Compiler. 

UCSD (auch als UCSD-P oder UOS für Universal Operating System 

bezeichnet) unterscheidet sich von CP/M und MS-DOS durch drei 

Merkmale: 

- Konsequente Menüsteuerung anstelle einer Kommandosteuerung 
und damit enge Benutzerführung. 

- Bereitstellung einer komfortablen und abgeschlossenen Pro- 
grammentwicklungsumgebung (mit Editor, Filer, Compiler, ...) 
anstelle einer reinen Laufzeitumgebung. 

- Hervorragende Portabilität durch die Mitnahme der Computer- 
architektur. 

Das UCSD-Betriebssystem ist prozessorunabhängig und damit für 

Personalcomputer jeglichen Prozessortyps einsetzbar. 

Wie ist dies möglich? UCSD benutzt den jeweiligen Personalcom- 

puter als Host-Computer im Sinne eines Wirtes bzw. Gastgebers. 

Es arbeitet also nicht unmittelbar mit dem Personalcomputer, 

sondern mit einem Pseudo-Computer. Gibt der Benutzer z.B. ein 

Quellenproggramm in PASCAL ein, so übersetzt der Compiler die- 

ses Textfile in einen Zwischencode (vgl. Abschnitt 1.3.6.3), 

der P-Code genannt wird, um das resultierende P-Code-File dann 
ebenfalls abzuspeichern. Soll dieses Programm nun ausgeführt 
werden, so wird es von einem P-Code-Interpreter vom P-Code in 
die Maschinensprache des jeweiligen Personalcomputers als Host 
übersetzt. Der Compiler ist fester Bestandteil des Betriebs- 
systems und selbst in PASCAL geschrieben. Der P-Code-Interpre- 
ter dagegen ist in der Maschinensprache des Hosts geschrieben. 
Soll UCSD auf einem Personalcomputer implementiert werden, so 
ist u.a. nur ein P-Code-Interpreter für die entsprechende CPU 
zu schreiben. Da UCSD auf einem P-Computer als abstraktem Com- 
puter läuft, der allein softwaremäßig auf dem Personalcomputer 
als Host nachgebildet wird, ist eine rasche Verfügbarkeit die- 
ses Betriebssystems auf neuen Personalcomputern zu erwarten. 





Benutzer- Pseudo-Computer Personalcomputer 

eingabe: als P-Computer: als Host-Computer: 

Quellcode Objektcode 1 Objektcode 2 

als Textcode als P-Code als Maschinencode 
Compiler P-Code-Interpreter 
übersetzt übersetzt 


(P=Pseudo) 


UCSD behandelt den Personalcomputer als Host bzw. Gast 


Der Trend geht eindeutig dahin, meh re r e Betriebssysteme 
für einen Computer bereitzustellen. So sind für den IBM Perso- 
nalcomputer die drei Betriebssysteme MS-DOS von Microsoft, 
CP/M-86 und UCSD-P nutzbar. 
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1.3.7 Anwender-Software entwickeln 


Die Programmentwicklung wird als Teil der DV-Systementwicklung 
vorgenommen und vollzieht sich wie diese in Teilschritten. Mag 
die Terminologie hierzu auch unterschiedlich sein, die Pro- 
grammentwicklung wird stets in der Schrittfolge "PROBLEMSTEL- 
LUNG - PROGRAMMENTWURF - PROGRAMMIERUNG - ANWENDUNG" durch- 
geführt werden. Am Beispiel der Rechnungsstellung bzw. Faktu- 
rierung wollen wir diese Teilschritte im Abriß kurz erläutern. 


Prog räna en ew io.k- I ung 


[DOKUMEN- 
TATION 


PROBLEM-| [| PROGRAMMENTWURF: I[ PROGRAMMIERUNG: 


STELLUNG 









Problemanalyse: 


— 


- Teilprobleme 
(Module) 
- A-E-V-Analyse 





Codierung 


ANWENDUNG 





Algorithmus (Ablauf):|] Eingabe 


u u un Mus mE. mm IM: „mm Mm: je mE Mm sim Mi sim Ad ii Mm: Tamm 


Darstellungsformen: 
Schrittplan 
Blockdiagramm 
Datenflußplan 
Programmablaufplan 
Struktogramm 
Entwurfsprache 


Übersetzung 







Programmtext 





Programmentwicklung in Teilschritten 


1.3.7.1. Problemanalyse 


Ein Problem analysieren heißt, dieses in seine Bestandteile zu 
zerlegen. Bei der Problemanalyse geht man nach der Idee 'Vom 
Einfachen zum Schwierigen' von den Ausgabedaten aus, da diese 
ja mit der Problemstellung als erwartetem Resultat vorgegeben 
sind. Erst danach wendet man sich der Analyse der Eingabe und 
der Verarbeitung zu. 

Ausgabe-Analyse: Daten (z.B. Rechnungszeile mit Artikelnummer, 
Bezeichnung, Menge, Einheit, Einzel- und Gesamtpreis), Form 
(z.B. Drucker für Rechnung, Diskette für Offene-Posten-Datei), 
Listbilder zum Ausgabeformat, Zeitpunkt der Ausgabe. 
Eingabe-Analyse: Daten (Kundennummer, Artikelnummer und Anzahl 
sowie Datum), Form (z.B. Tastatur, Diskette für Kundendatei u. 
Artikeldatei). 

Verarbeitungs-Analyse: Die Verarbeitungsschritte ergeben sich 
aus den Ausgabe- und Eingabeanforderungen (z.B. Menge*Einzel- 
preis ergibt Gesamtpreis). 

In einer Variablenliste werden sämtliche Namen mit Datentypen 
zusammengefaßt. In einem Datei-Verzeichnis werden die Dateien 
mit den entsprechenden Datensatz-Beschreibungen festgehalten. 
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1.3.7.2 Formen zur Darstellung des Lösungsablaufes 


Für den dann zu entwickelnden Algorithmus bzw. Lösungsablauf 
stehen die unterschiedlichen Darstellungsformen zur Verfügung. 


n Schritt plan kann jetzt so aussehen: 
. Rechnungs- und Kundennummer mit Datum eintippen. 
Rechnungskopf drucken 

Rechnungszeile(n) aufbereiten und drucken 
Rechnungsabschluß drucken 

. Kundendatei aktualisieren 

. Eintrag Offene-Posten-Datei 


E 


NIBWN - P- 
.o.0.00 


Als Blockdiagramm kann dieser Schrittplan schon 
feiner gegliedert bzw. strukturiert sein wie z.B. Schritt 1: 


Tastatur- Ausgabe 
eingabe Kundensatz 


Zu 'Kunde prüfen': Ist ein Kunde mit der eingetippten Nummer 
nicht in der Kundendatei enthalten, wird eine Meldung ausgege- 
ben. Zu "Ausgabe Kundensatz': Zur Kontrolle wird der gesamte 
Inhalt des Kundensatzes am Bildschirm gezeigt. 


Schritt 1 





Im Daten f lu ß p lan werden die Datenträger bzw. Ge- 
räte, die Arten der Bearbeitung und der Datenfluß zwischen den 
Datenträgern grafisch festgehalten. 





Sinnbilder für Datenflußpläne nach DIN 66001 
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Für die Rechnungsschreibung könnte der Datenflußplan in seiner 
knappsten Form etwa so aussehen: 


Tastatur- N Rechnungs- 
eingabe ausdruck 


Rechnungs- 


ee men Ra a 


Kundendatei Artikeldatei OÖffene- ‚Posten- Datei 
Einfacher Datenflußplan zur Rechnungsschreibung 


Der Datenflußplan bezieht sich mehr auf die Hardware, während 
der Programmablauf plan (PAP) mit der zeich- 
nerischen Darstellung des geplanten Programmablaufes eindeutig 
softwarebezogen ist. Die Sinnbilder für den PAP sind ebenfalls 
nach DIN 66001 genormt. Im Datenflußplan wie im PAP gleichbe- 
deutend sind die Sinnbilder für Anschlußpunkt sowie für Be- 
merkung. Eine im PAP etwas andere Bedeutung hat das Rechteck 
(Wertzuweisung) und das Parallelogramm (Eingabe , Ausgabe). 
Neu im PAP sind die 

Sinnbilder für die 

Verzweigung und für 

das Aufrufen eines 

Unterprogramnms. Verzweigung Unterprogramm 


Die zum Teilschritt "Kunde prüfen' (obiger Schrittplan) zuge- 
hörige Anweisungsfolge kann als PAP z.B. so aussehen: 


Kundennummer eintippen 


Kunde auf Datei vorhanden? Fehler- 
meldung 
ausgeben 

Wenn Kundennummer ungultig, 

dann Zurückverzweigen 


Neben dem PAP wird immer häufiger ein weiteres Hilfsmittel zur 
zeichnerischen Darstellung von Programmabläufen verwendet: das 
Struktogramm, auch Strukturdiagramm oder (nach dem 
Erfinder) Nassi-Shneiderman-Diagramm genannt. Struktogramme 
haben wir bereits in Abschnitt 1.3.3 verwendet, um damit die 
grundlegenden Programmstrukturen darzustellen. 
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Im folgenden Struktogramm wird der Ablauf 'Kunde prüfen' dar- 
gestellt: 


Kundennummer eintippen 


Kunde auf Datei? 


af Fehlermeldung ausgeben 


Wiederhole bis gültige Kundennummer eingetippt wurde 





Beim Struktogramm sind die Programmstrukturen deutlich erkenn- 
bar: eine nicht-abweisende Schleife, die eine 'Einseitige Aus- 
wahl' einschachtelt. 


Neben diesen grafischen Darstellungsmöglichkeiten des Lösungs- 
ablaufes verwendet man oft eine Entwurfsprache 
als Pseudocode, um den Programmentwurf umgangssprachlich dar- 
zustellen (Abschnitt 1.3.3.1). Der oben als PAP sowie Strukto- 
gramm dargestellte Ablauf läßt sich in der Entwurfsprache wie 
folgt beschreiben; 


Wiederhole 
Tippe die Kundennummer ein 
wenn die Kundennummer in der Kundendatei gefunden wurde 
dann tue nichts 
sonst zeige eine Fehlermeldung am Bildschirm 
Ende-wenn 


bis eine Kundennummer als gültig erkannt wurde 


Der algorithmische Entwurf stellt häufig die unmittelbare Vor- 
stufe zur Programmierung dar. 


1.3.7.3 Programmierung 


Programmier - System am Bildschirm aufrufen 


Codierung und Eingabe 
(= Editieren über einen Editor) 


Übersetzen 
(= Compilieren über einen Compiler) 


wiederhole, bis Programm syntax-fehlerfrei 


| Testen (Ausführung, Pogrammlauf) 





wiederhole, bis Programm logisch fehlerfrei 


Programmieren im engeren Sinne als Struktogramm 
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Programmieren heißt, den zeichnerisch und/oder verbal darge- 
stellten Algorithmus in eine Programmiersprache umzusetzen und 
auszutesten. Dabei werden die Schritte "'Codierung', "Eingabe', 
"Übersetzung' und 'Testen' zumeist wiederholt durchlaufen. Der 
Übersetzungslauf als gesonderter Schritt ist bei Sprachen mit 
Compiler, nicht aber bei solchen mit Interpreter erforderlich 
(vgl. Abschnitt 1.3.6.3). Das Austesten erfolgt als Computer- 
test sowie Schreibtischtest. 


Abschließend faßt man mit der Dokumentation alle 
Programmunterlagen als Gebrauchsanleitung zusammen: sei es als 
Anleitung für den Operator, damit dieser den Computer bei den 
Programmläufen auch richtig bedienen kann (Operator-Handbuch), 
oder als Anleitung für den Benutzer für die spätere Programn- 
pflege und Programmkorrektur (Benutzer-Handbuch). Zusätzlich 
zum Benutzer-Handbuch sollte eine Kurzanleitung vorliegen, die 
nur die wichtigsten für den Umgang mit dem Programm notwendi- 
gen Schritte und Anweisungen für den Interessenten bereithält. 


zentraler Teil der Programmentwicklung ist der Programmentwurf 
und nicht -wie es manchem DV-Einsteiger scheinen mag- die Pro- 
grammierung bzw. Codierung in einer Programmiersprache. Es ist 
denkbar, daß die Codierung eines Tages automatisiert durchge- 
führt werden kann. 

Angesichts der steigenden Software - Kosten (Abschnitt 1.1.2) 
geht man immer mehr dazu über, die Programmentwicklung und da- 
bei besonders den Programmentwurf industriell und ingenieur- 
mäßig vorzunehmen: software - Engineering 
lautet die darauf verweisende Begriffsbildung. Auf einige der 
im Rahmen des Software-Engineering eingesetzten Programmier- 
techniken sowie Entwurfsprinzipien gehen wir nachfolgend ein. 


1.3.7.4 Programmiertechniken und Entwurfprinzipien 


Die Modulari sierung von Software berücksich- 
tigt, daß ein in kleine Teile bzw. Moduln gegliedertes Problem 
bzw. Programm . einfacher zu bearbeiten ist. 'Klein' heißt, daß 
ein Modul maximal 200 Anweisungen umfassen darf. Ein Modul ist 
ein Programmteil mit einem Eingang und einem Ausgang und kann 
selbständig übersetzt und ausgeführt werden. Moduln verkehren 
nur über Schnittstellen miteinander, über die Werte (Parameter 
genannt) vom rufenden an das aufgerufene Modul übergeben wer- 
den; ein Modul darf als Black Box nichts vom Innenleben eines 
anderen Moduls wissen. 


Die Normier ung von Programmabläufen als Vereinheit- 
lichung durch eine standardisierte Ablaufsteuerung wird bei 
der Entwicklung komplexer kommerzieller Software-Pakete vorge- 
nommen, an der zumeist mehrere Mitarbeiter beteiligt sind. Je- 
des Softwarehaus hat seine eigenen Normen. 


Die Jackson - Methode geht bei der Pogramment- 
wicklung von der exakten Analyse der Datenstrukturen aus, um 
dann die entsprechenden Pogramm- bzw. Ablaufstrukturen zu ent- 
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werfen. Warum? In der kommerziellen DV sind die Daten zumeist 
bis in die Details vorgegeben, während die Abläufe den Daten 
gemäß formuliert werden müssen. Anders ausgedrückt: die Daten- 
struktur prägt die Programmstruktur. 


Dem Top - Down - Entwurf als Von-oben-nach- 
unten-Entwurf entspricht die Technik der schrittweisen Verfei- 
nerung: vom Gesamtproblem ausgehend bildet man Teilprobleme, 
um diese dann schrittweise weiter zu unterteilen und zu ver- 
feinern bis hin zum lauffähigen Programm. Der Top-Down-Entwurf 
führt immer zu einem hierarchisch gegliederten Programmaufbau. 


Der Bottom - Up - Entwurf als Gegenstück zum 
Top-Down-Entwurf geht als Von-unten-nach-oben-Entwurf von den 
oft verwendeten Teilproblemen der untersten Ebene aus, um suk- 
zessive solche Teilprobleme zu integrieren. Beide Entwurfs- 
prinzipien werden in der Praxis zumeist kombiniert angewendet. 


Die Unterprogrammtechnik wird in diesen 
drei Fällen genutzt:Ein Ablauf wird mehrfach benötigt; mehrere 
Personen kooperieren und liefern ihre Teilproblemlösungen als 
Unterprogramme ab; menügesteuerter Dialog (Menütechnik). Der 
Begriff des Unterprogramms bzw. der Prozedur entspricht dabei 
dem des Moduls. Die bekannteste Schnittstelle ist der Unter- 
programmaufruf mit Parameterübergabe. 


Die Menütechn ik erleichtert den benutzergesteuer- 
ten Dialog. Über das Menü als Auswahlübersicht steuert der Be- 
nutzer den Ablauf des Programms, ohne zuerst alle Befehle ler- 
nen zu müssen. 

Das Menü als Gedächtnisstütze bei der Eingabe kann in Tabel- 
lenform alternativ zum Bildschirm, auf dem sonst der Dialog 
protokolliert wird, angeboten werden. Dies setzt den schnellen 
wechsel zwischen den Bildschirmseiten voraus. Oder das Menü 
wird als (Prompt-)Zeile ausgegeben, die zusätzlich zum Dialog 
ständig am oberen Bildschirmrand stehen bleibt. 

Bei der Split-Screen-Technik werden Rechteckbereiche des Bild- 
schirms wie eigenständige Bildschirme bzw. Fenster behandelt. 
Über ein solches Fenstersystem kann der Benutzer Menüs an je- 
der Stelle des Bildschirms erscheinen lassen. 

Die Menütechnik kann sich auf das Arbeiten innerhalb 
eines Programms wie auch auf das Verbinden mehrerer Programme 
beziehen. Im letzteren Fall wird beim Einschalten des Compu- 
ters bzw. beim Beenden eines Programms automatisch ein Menü- 
programm geladen, das am Monitor alle verfügbaren Programme 
anzeigt; der Benutzer kann durch Tippen z.B. eines Buchstabens 
dann das gewünschte Programm laden, ohne sich um den Speicher- 
ort auf Diskette kümmern zu müssen. Hierarchische 
Menüs teilen eine Aufgabe in übergeordnete Menü-Ebenen auf. 
Im Hauptmenü stehen häufig verwendete Funktionen und nach der 
Wahl erscheint das nächste Menü mit weiter detaillierten Funk- 
tionen. 

Pop-up-Menüs erscheinen auf Tastendruck, bieten mehrere Mög- 
lichkeiten zur Auswahl an und verschwinden, sobald eine Wahl 
getroffen wurde. Pop-up-Menüs halten also nicht auf und lenken 
auch nicht ab: sie erscheinen nur, wenn sie auch benötigt wer- 
en. 

Die Menüwahl erfolgt durch Klartexteingabe (Fehlerrisiko groß) 
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bzw. durch Tasten eines Zeichens oder dadurch, daß der Cursor 
auf die gewünschte Position gesetzt wird und dann die RETURN- 
Taste gedrückt wird. Die Menüwahl vereinfacht sich weiter bei 
Einsatz von Lichtgriffel oder Maus. 


Bei der Overlaytechn ik werden Moduln überlagert 
(=overlay) - z.B. wenn der Hauptspeicherplatz nicht ausreicht, 
um alle Moduln gleichzeitig aufzunehmen. Das im Hauptspeicher 
stehende Modul ruft ein anderes Modul auf, das dann von einem 
Externspeicher geladen und dem rufenden Modul überlagert wird. 


Der strukturierte Ent wur f bedeutet, daß 
ein Programm unabhängig von seiner Größe nur aus den vier (in 
Abschnitt 1.3.3 erklärten) grundlegenden Programmstrukturen 
aufgebaut sein darf: aus Folge-, Auswahl-, Wiederholungs- so- 
wie Unterprogrammstrukturen. Dabei soll auf unbedingtes Ver- 
zweigen mittels GOTO verzichtet werden. Jede Programmstruktur 
bildet einen Strukturblock. Blöcke sind entweder hintereinan- 
der angeordnet oder vollständig geschachtelt - die teilweise 
Einschachtelung (Überlappung) ist nicht zulässig. 

Sogenannte 'blockorientierte Sprachen' wie PASCAL, MODULA-2, 
ELAN und ADA unterstützen das Prinzip des strukturierten Ent- 
wurfs weit mehr als die "unstrukturierten Sprachen' wie BASIC 
und APL. 


Diese nur stichwortartig dargestellten Prinzipien dürfen nicht 
getrennt betrachtet werden; unter dem Informatik-Sammelbegriff 
strukturierte Programmierung faßt 
man sie zu einem heute allgemein anerkannten Vorgehen zusam- 
men. Die tragenden Prinzipien sind dabei der Top-Down-Entwurf 
mit der schrittweisen Verfeinerung einerseits und der struk- 
turierte Entwurf mit der Blockbildung andererseits. 


1.3.7.5 Programmgeneratoren 


Ein Programmgenerat or hat als Zwischenlösung 
seinen Standort zwischen der Programmierung in einer höheren 
Programmiersprache (BASIC, PASCAL) einerseits und dem Anpassen 
eines gekauften Anwenderprogramms durch Änderung der dafür an- 
gegebenen Parameter andererseits. 

So können im Dialog Benutzer-Computer Masken (Formulare) sowie 
Programmbeschreibungen erstellt werden, aus denen später z.B. 
BASIC-Anweisungen generiert, d.h. erzeugt werden. Die so er- 
zeugten BASIC-Programme sind über einen Interpreter lauffähig, 
können ggf. aber auch noch compiliert werden. 


Entsprechend spezialisiert werden Programmgeneratoren als Mas- 
kengenerator, Listengenerator, Grafikgenerator usw. bezeichnet 
und vor allem im Rahmen von Standard-Software bereitgestellt. 
Zum Maskengenerator ein Beispiel: Soll eine Maske für die Kun- 
dendatei erstellt werden, dann wird nach Aufruf des Generators 
auf dem Bildschirm eine Grundeinteilung vorgenommen. Der Be- 
nutzer setzt den Cursor dann auf die Stelle, an der ein Daten- 
feld angelegt werden soll, gibt die Bezeichnung ein (NAME) so- 
wie die Feldlänge (mit Cursor 20 Stellen nach rechts fahren). 
Auf diese Weise wird eine Bildschirmmaske aufgebaut. Der Gene- 
rator kann dann eine der Maske (als Blankoformular vorzustel- 
len) entsprechende Datei erzeugen bzw. einrichten. 
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1.3.8 Anwender-Software einsetzen 


Der Anwender hat drei Möglichkeiten, seinen Personalcomputer 
mit Software zu versorgen: Er kann selbst Programme entwickeln 
und den Computer als frei programmierbares Gerät nutzen - da- 
rauf sind wir im vorangehenden Abschnitt 1.3.7 eingegangen. Er 
kann aber auch fremde Software-Produkte kaufen: sei es in Form 


von individueller Software ‚ die (ent- 
sprechend teuer) genau nach seinen Vorgaben entwickelt wird, 
sei es in Form von Standard - Software, die 


zwar preisgünstiger ist, aber das Risiko birgt, die eigenen 
Organisationsstrukturen anpassen zu müssen. Als Kompromiß zwi- 
schen der kompletten Individuallösung und der standardisierten 
Allgemeinlösung versucht man, individuelle Software auf Stan- 
dardbasis zu entwickeln; dabei wird entweder über Programmge- 
neratoren bzw. Kommandosprachen programmiert oder über zwei 
logische Variablenebenen. 


1.3.8.1 Menügesteuerter oder kommandogesteuerter Dialog 


Beim Einsatz fremder Software muß der Benutzer sicher und kom- 
fortabel durchs Programm geführt werden, es kommt also auf die 
Benutzerführung an. Dabei bieten sich menü- und 
kommandogesteuerte Anwendungen an. 


Der Anfänger wird die Menüsteue rung schätzen; er 
wird über die ihm gerade zur Verfügung stehenden Eingabemög- 
lichkeiten - zum Menü zusammengefaßt - am Bildschirm jederzeit 
informiert, mehr noch: diese Möglichkeiten sind eingegrenzt, 
um den Benutzer relativ eng zu führen. Der Anfänger kann sich 
so ohne langes Handbuch-Studium an den Programmeinsatz wagen. 
Kennt er sich einmal im Programm aus, so wird der Weg durch 
Menüs und Menü-Ebenen allerdings auch als Hemmnis empfunden. 


Dann bietet sich die Kommandosteuerung über 
Kommandos an, die in einem Handbuch aufgelistet sind und vom 
Benutzer wahlfrei eingetippt werden können - mit dem Risiko 
entsprechender Fehlermeldungen natürlich. 


Gute Anwenderprogramme können beide Arten der Benutzerführung 
vorsehen: arbeitet der Benutzer fehlerlos, dann läuft das Pro- 
gramm kommandogesteuert ab, um bei häufiger auftretenden Feh- 
lern in einen menügesteuerten Ablauf zu wechseln. 

Oft werden auch zwei Bildschirm s e i t e n vorgesehen: eine 
Hauptseite mit dem eigentlichen Dialog sowie eine zusätzliche 
Hilfsseite mit Kommentaren und Texthilfen, zwischen denen der 
Benutzer jederzeit hin und her springen kann. 


Die Dialogsteuerung über Menü und Kommando ist bei der System- 
Software natürlich ebenso zu finden wie bei der Anwender-Soft- 
ware. So ist z.B. das Betriebssystem UCSD rein menügesteuert. 
Dies steht im Gegensatz zur Kommandosteuerung bei CP/M. 


1.3.8.2 Einige Programm-Qualitätsmerkmale 


Es soll hier kein Merkmalskatalog formuliert werden (dies auch 
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im Hinblick darauf, daß solche Merkmale für Software äußerst 
schwer meßbar sind), sondern einige praktikable Einzeltips: 


Wird Anwendersoftware zu einem Turn - Key - Paket 
geschnürt verkauft, so startet das (Menü-)Programm automatisch 
sofort nach dem Einschalten des Computers (Programmladen sowie 
Betriebssystem-Kenntnisse sind dann nicht erforderlich). 


Beim Sc ro 1 1 in g rutscht der Bildschirminhalt um eine 
Zeile hoch, wenn der Cursor unten den Bildrand erreicht hat. 
Zum schnellen Durchblättern zusammenhängender Texte kann die- 
ses Durchrollen von Information vorteilhaft sein. Andernfalls 
wird man den Bildschirm abschnittsweise total löschen und oben 
am Bildschirm neu beginnen. 


Beim Screen Edi tin g kann der Benutzer den Cur- 
sor an jede beliebige Bildschirmposition bewegen, um dort dann 
etwas zu korrigieren oder neu einzugeben. Der Bildschirm dient 
als Arbeitsblatt, -seite bzw. Formular. Sehr häufig bleibt am 
Bildschirmrand eine Menüzeile (auch Prompt- oder Systemzeile 
genannt) permanent stehen, um den Benutzer über Steuerungsmög- 
lichkeiten (Kommandos) und aktuelle Parameter (wie Zeilenlänge 
oder freien Speicherplatz) zu informieren. 


Die Zeichendarstellung darf nicht zu verwirrend sein. Häufige 
Invers - Felder (dunklere Schrift auf hellem Hin- 
tergrund) führen z.B. zu erhöhter Augenbelastung und sollten 
sparsam verwendet werden. 


Eine benutzerfreundliche Fehlerbehandlwung muß 
a 1l le möglichen Fehler abfangen (Plausibilitätskontrollen). 


Zur Sicherheit müssen Tasten, die zum Absturz füh- 
ren (z.B. ESC-Taste), gesperrt sein. Keine Eingabe, auch nicht 
die 'berühmte' Division durch Null, darf dabei zum Aussteigen 
führen (Deadlock-Situation), die ein Abschalten und Neustarten 
erforderlich macht. Zur Sicherheit zählt auch die Datenschutz- 
fähigkeit eines Programms. 


Die Zuverlässigkeit nimmt den sicher höchsten 
Rang ein: das raffinierteste Programm ist wertlos, wenn es die 
Aufgaben nicht zuverlässig löst. 


Der Software-Qualitätssicherung wird heute im Rahmen des Soft- 
ware-Engineering mehr und mehr Beachtung geschenkt. 


1.3.8.3 Vier kaufmännische Standard-Programmpakete 


Die vier Programme Tabellenkalulation, Textverarbeitung, Datei 
bzw. Datenbank und Grafik sind fast auf jedem Personalcomputer 
Standard - voneinander isoliert oder auch integriert. 


Tabel]lenkalkulationsprogramme als 
'Spread Sheets' bzw. "Ausgebreitete Papierbogen' übertragen 
alles das, was bislang mit Bleistift, Papier und Taschenrech- 
ner vorgenommen wurde, in den Hauptspeicher (abgelegt) und auf 
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den Bildschirm (gezeigt). Der Benutzer baut jedes Arbeitsblatt 
als Tabelle auf, kann in die Tabellenzeilen und -spalten nume- 
rische oder auch Textwerte eintragen und durch eine Vielzahl 
von Formeln verknüpfen. Bei 'Visicalc' als dem ersten größeren 
Kalkulationsprogramm werden die Tabellenelemente ähnlich dem 
Schachbrett (Namen A1,A2,A3,...) angesprochen; 'Multiplan' als 
jJüngeres Konkurrenzprogramm von Microsoft ermöglicht dies mit- 
tels einfacher Cursor-Positionierung am Bildschirm. Arbeits- 
blätter können auf einem externen Speicher aufbewahrt werden. 
Tabellenkalkulationsprogramme lassen sich 'zweckendfremden': 
Trägt man Text anstelle von Zahlen in die Tabelle ein, so kann 
leicht eine kleines Informationssystem realisiert werden. Ge- 
nauso sind Anwendungen zur Fakturierung, zum Bestellwesen, zur 
Bilanzierung usw. denkbar. Das Beiwort 'Kalkulation' verweist 
also eher auf die Ursprünge der Tabellenkalkulationsprogramme 
als auf deren heutige universellen Nutzungsmöglichkeiten. 


Textverarbeitungsprogramme für Per- 
sonalcomputer sind aus den Editoren entstanden, also aus den 
Programmhilfen zum Eingeben und Aufbereiten von Programmen am 
Bildschirm. Man hat sie zur Verarbeitung anderer Dokumente 
wie Briefen, Rechnungen, Manuskripten, Formularen usw. weiter- 
entwickelt. Damit treten sie in Konkurrenz zur Schreibmaschi- 
ne, zum Text-Automaten sowie zur Großrechner-Textverarbeitung. 
Die Textverarbeitung umfaßt die Teilprogramme Editor, Ausga- 
beformatierer und Verarbeitung; diese Programme können zu ei- 
nem Paket integriert oder getrennt sein. 
- Editor als Eingabe- und Bearbeitungsprogramm: 
Der Bildschirm wird ähnlich wie eine Lupe über den Text be- 
wegt bis zu einem Bildschirmausschnitt, der cursorgesteuert 
zu bearbeiten ist (verschieben, einfügen, kopieren, Rand 
ausgleichen usw.). 
- Formatierer zur Aufbereitung der Druckausgabe: 
Man unterscheidet die folgenden zwei Arten von Formatierern. 
Bei der ersten Art erscheint der Text am Bildschirm so, wie 
er später ausgedruckt wird. Bei der zweiten Art sind in den 
Bildschirmtext Befehle zur Steuerung des Druckformates ein- 
gefügt. Bei der ersten Art wird "gedruckt wie gezeigt'. Oft 
ist dies aber kaum exakt einzuhalten (Beispiel: 120 Zeichen 
je Druckzeile; Bildschirmzeile 80 Zeichen; Ausgabe-Text aus 
mehreren Dateien). 
- Eigentliches Verarbeitungsprogramm: 
Dieses richtet sich nach den Anforderungen der unterschied- 
lichen Benutzer wie Sekretärin, Abteilungsleiter, Schrift- 
steller, Schriftsetzer. Textbausteine als häufig vorkommen- 
de Textteile speichern, Serien- sowie Ganzbriefe erstellen, 
Formulararbeiten, Textdateien anlegen, Autorenkorrektur usw. 


Nach den Programmen zur Tabellenkalkulation und Textverarbei- 
tung nun zur Datei / Datenbank , deren Grund- 
lagen bereits in Abschnitt 1.3.5 dargestellt wurden. 

Die kommerziellen Programm-Pakete hierzu werden unter den un- 
terschiedlichsten Bezeichnungen angeboten, z.B. als Dateiver- 
waltung, Datenmanager, Datenbankmeister, Datenbank-System oder 
schlicht als Datei-System. Da solche Begriffe kaum etwas aus- 
sagen, ist es sinnvoll, einzelne Eigenschaften dieser oft als 
"wir-können-alles-Programme" angepriesenen Software-Produkte 
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wie folgt zu überprüfen: 

- Dateiaufbau: | 
Anzahl der gleichzeitig geöffneten Dateien? Satzanzahl einer 
Datei? Anzahl der Datenfelder je Satz? Feste Satzlänge? Da- 
tentypen? Maximale Feldlänge? Maximale Dateigröße? Eine Da- 
tei auf mehreren Disketten? 

- Systemverwaltung: 
Schnittstelle zu höheren Programmiersprachen? In Mehrplatz- 
Umgebung einsetzbar? Abfragesprachen, Listen- bzw. Programm- 
generatoren? Dynamische Dateiverwaltung? Kompatibilität zu 
anderen Dateien (z.B. aus Textverarbeitung)? Datensatzaufbau 
nachträglich änderbar? Implementierungen für welche Mikros? 
Datei-Sicherheitskopien leicht erstellbar? Daten nach Lösch- 
en wiederherstellbar? Datenschutz durch Datei- bzw. Satzpaß- 
wort? Realisierung als Datenbankmaschine? 

- Speicherung: 
Aufwand zum Neueinrichten der Datenbank? Cursorsteuerung? 
Datenprüfung bei Eingabe? Daten aus anderen Dateien kopier- 
bar? Speicherung satz-, block- oder dateiweise? Eingabefeh- 
lerkorrektur möglich? Ablegen als Binärdatei oder Textdatei? 

- Zugriff: 
zugriffsmodus direkt oder indirekt? Anzahl der Suchbegriffe? 
Schlüssel aus einem oder mehreren Datenfeldern bestehend? 
Sortierbegriffe für wieviele Datenfelder? Sortierprogramme? 
Index intern als Tabelle? Möglichkeiten zur Datenausgabe? 
"Ausgabeeinheiten für Listen? Zwischensummenbildung in Lis- 
ten möglich? 


zum Grafikprogramm als viertem Standard-Paket: 
Programme dieser Kategorie erlauben es, Kuchen-, Säulen- sowie 
Liniengrafiken menügesteuert über einen hochauflösenden Bild- 
schirm und z.B. einen Matrixdrucker mit Einzelpunktansteuerung 
zu erstellen und auszugeben. Die Skalierung der Bilder kann im 
Dialog festgelegt werden. Oft können dreidimensionale Grafiken 
bzw. räumliche Formen erzeugt werden. Gerade für kommerzielle 
Veranschaulichungen sind Grafikprogramme mit den statistischen 
Grundfunktionen von Vorteil. 

Ein Grafikprogramm kann nur dann sinnvoll genutzt werden, wenn 
man Daten aus anderen Programmen übergeben kann. Wir kommen so 
zur Frage der Verbindung bzw. Kompatibilität dieser Programme. 


Sollen Tabellenkalkulation, Textverarbeitung, Datenbank sowie 
Grafik nicht isoliert, sondern als eine Einheit genutzt werden, 
müssen entsprechende Schnittstellen zu den Programmen gegeben 
sein. Zur Verbindung dieser Programme ein Beispiel: 

In einem Tabellenkalkulationsprogramm verknüpft man Zahlen, um 
diese dann an ein Grafikprogramm zwecks Diagrammdarstellung zu 
übergeben. Anschließend wird über das Textverarbeitungspro- 
gramm ein Bericht verfaßt, in den diese Zahlen als Tabelle wie 
auch als Diagramm bildlich eingebunden sind. Schließlich kann 
man die Teile dieser Arbeit über das Dateiprogramm extern und 
langfristig speichern. 

Wie können die vier Programme nun verbunden werden? Zum Bei- 
spiel über Textdateien (alle Zeichen als Text im ASCII-Code 
dargestellt) als gemeinsamer Schnittstelle. Die Steuerung kann 
über ein übergeordnetes Menüprogramm erfolgen, das die einzel- 
nen Programme aufruft und den Datenaustausch überwacht. 
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1.3.8.4 Teillösung und Gesamtlösung im Betrieb 


Wird ein Personalcomputer im kleineren Betrieb als Allzweck- 
System eingesetzt, dann sicher mit dem (Fern-)Ziel, sämtliche 
betrieblichen Funktionen wie Materialwirtschaft, Betriebsab- 
rechnung, Finanzbuchhaltung, Personalwesen sowie Auftragsbear- 
beitung über e i n Software-Paket zu bearbeiten: man spricht 
dabei von "integrierter DV' (vgl. Abschnitt 1.3.5.5). Auf dem 
weiten Weg zu einer solchen Gesamtlö6ösung wird man 
zunächst als Te i 1165 s ung einzelne Funktionen auf die 
DV übernehmen: So die Fakturierung der Ausgangsrechnungen mit 
Kunden-, Artikelstamm- und Offene-Posten-Datei, die später in 
die Auftragsbearbeitung integriert werden kann. Oder als wei- 
tere Teillösung das Personalwesen mit Lohn- und Gehaltsabrech- 
nung mit der späteren Anbindung zur Finanzbuchhaltung mit Kre- 
ditoren-, Debitoren- und Sachbuchhaltung. 





BUCHHALTUNG: PERSONALWESEN: 
Kreditoren, Debitoren, Stammdatenverwaltung, 
Sachkontenverwaltung, Monatsgehalt, 
Offene Posten, Bilanz, _- Überweisungsträger, 
Erfolgsrechnung, »>»« SER ee Nachweislisten, ... 
MATERIALWIRTSCHAFT: PERSONAL - BETRIEBSABRECHNUNG: 
Permanente Inventur, ” | COMPUTER | Nachkalkulation, 
Lagerbestandsführung, — Umsatzstatistik, 
Bestellwesen, ... Kostensätze, ... 
AUFTRAGSBEARBEITUNG: 


Auftragsverwaltung, 
Erfassung, Rückstände, 
Fakturierung, ».., 


Integrierte Datenverarbeitung als Ziel 


Anwender-Software, die eine integrierte Bearbeitung aller in- 
nerbetrieblichen Vorgänge ermöglichen soll, wird immer häufi- 
ger als Branchen 1 ©6ös ung angeboten. Diese ist auf 
eine bestimmte Branche gerichtet. Beispiele: Handwerksbetrieb, 
Rechtsanwaltskanzlei, Immobilienfirma, Großhandel, Versicher- 
ung, Zahnarztpraxis, Einzelhandel, Leasing oder Vertreter. 


1.3.8.5 Nicht nur am Rande: Spielprogramme 


"Immerhin noch besser als das n ur passive Fernsehen" - so 
wird das Vordringen der "Arcade-Games' genannten, computerge- 
steuerten Spiele von der Spielhalle ins Wohnzimmer sehr häufig 
kommentiert. 

Gespielt wird mit reinen Spielautomaten ('rein', weil sie aus- 
schließlich zum Spielen da sind; "Automat', da sie nicht frei 
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programmierbar sind und deswegen strenggenommen auch nicht als 
Computer bezeichnet werden dürfen) oder mit Personalcomputern, 
die auch hardwaremäßig durch Steuerknüppel (Joystick), Auslö- 
setaste, Lichtgriffel usw. entsprechend ausgestattet sind. Ge- 
rätehersteller und spezialisierte Softwareproduzenten teilen 
sich den Markt. Angeboten werden die Spielprogramme dabei auf 
Einsteckmodul (Firmware) und auf Kassette wie Diskette (Soft- 
ware). Die vom Hersteller programmierten ROM-Moduln sind sehr 
einfach zu bedienen (Modul in den Schacht stecken und Programm 
starten) und vom Benutzer nicht zu kopieren. Da immer häufiger 
kommerziell genutzte Personalcomputer zum Spielen benutzt wer- 
den, wird das Spielangebot auf Kassette und Diskette bestimmt 
nicht abnehmen. 


Gemeinsam mit und gegen den Computer kann auf unterschiedliche 
Weise gespielt werden: 
- Geschicklichkeitsspiele: 
Übernahme altbekannter Spiele auf den Computer. 
- Neue Spielarten: 
Spiele wie Pac Man und Pillenfresser sind erst durch den 
Computer möglich geworden (Bewegung, hochauflösende Grafik). 
- Abenteuerspiele: 
von der Wirklichkeit in die Phantasiewelt am Bildschirm. 
- Simulations- und Rollenspiele: 
Modellbildung der Wirklichkeit; Planspieltechnik. 
- Spezielle Kinderspiele: 
... auch Mickey Mouse und Sesamstrasse. 
- Schachspielprogramme: 
Schon weniger als 'Spielzeug' abzutun. 
- Lehr- und Lernspiele: 
Fremdsprachen erlernen, naturwissenschaftliche Experimente, 
Computer-Unterstützter Unterricht (CUU), ... 


Bleiben die Unterhaltungsspiele, die weder die Kreativität an- 
regen noch das Denkvermögen fordern, weiter d i e vVerkaufs- 
schlager? 

werden in Zukunft auch die Lehr/Lernspiele nachgefragt? 

Wird der Computer als "perfekter Gespiele" den Menschen als 
"menschlich nicht-perfekten Spielpartner" noch mehr verdrängen 
können? 

In jedem Falle positiv: ganz im Gegensatz zum Konsumieren ist 
das Entwerfen und Programmieren neuer Spielprogramme ein sehr 
anregendes und kreatives Unterfangen. 


1.4 Firmware = halb Hardware + halb Software 


Als Firmware (feste Ware) hatten wir alle Information 
bezeichnet, die an der Nahtstelle zwischen Hardware und Soft- 
ware in computerverständlicher Form gespeichert vorliegt (vgl. 
Abschnitt 1.1.1). Speichermedium für Firmware ist der ROM als 
Festwert-Speicher. Für den ROM-Hersteller, der Information in 
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den ROM speichert, handelt es sich dabei um Software; für den 
Benutzer dagegen, der den ROM z.B. als Steck-Modul kauft, sind 
die Daten und Programme wie Hardware, da er sie nur anwenden 
(=lesen), nicht aber verändern (=beschreiben) kann. 


1.4.1 IC als Integrierter Schaltkreis 


Beim Öffnen des Gehäuses eines Personalcomputers entdeckt man 
in jedem Fall vier Teile: 


- Ein Netzteil bzw. Transformator als großes Teil zur Strom- 
versorgung. 

- Platinen als Leiterplatten, auf denen Schaltkreise (Chips) 
montiert sind. 

- Verbindungsleitungen 

- Stecker als Schnittstellen zum Kontakt mit der 'Außenwelt' 


wichtig sind die Chips. Ein Chip ist ein kleines Plätt- 
chen aus Silizium, auf das im Zuge der Herstellung bestimmte 
Schaltelemente zu einer untrennbaren Einheit eingeschmolzen 
bzw. integriert werden. Deshalb bezeichnet man den Chip auch 
als Integrierten Schaltkreis mit der 
Abkürzung IC für "Integrated Circuit'. Genaugenommen schmelzt 
man auf einen Chip mehrere Schichten aus jeweils verschiedenen 
Stoffen ein, deren Strukturen dann ein Verhalten ergeben, das 
einem Transistor, Kondensator, Widerstand usw. entspricht. 





Zwei grundsätzliche Verwendungsmöglickeiten von ICs 


Das Siliziumplättchen als Trägerkristall ist stets in ein Ge- 
häuse mit z.B. 16 Füßen (Pins) als Anschlüsse eingebaut. 
Je nach Anordnung der Bauelemente kann man einen Chip als Lo- 
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gikbaustein oder als Speicherbaustein verwenden: 

Wird ein Chip als aktiver Baustein zur Ausführung von Befehlen 
verwendet, dann nennt man den Chip Logikbaustein 
(weil nach einer bestimmten Ablauflogik vorgegangen wird) oder 
kurz Mikroprozessor. Der erste Mikroprozessor 
wurde 1970 auf den Markt gebracht. 

Der Chipals Speicherbaust ein zur Speicherung 
von Daten und Programmen wurde erst später entwickelt. Zwei 
Speicherarten unterscheidet man: Bei dem mehrfach erwähnten 
Speicher ROM (Read Only Memory) als Nur-Lese-Speicher kann der 
Benutzer nur lesen, da die Programme als Firmware fest im ROM 
gespeichert sind. Im Gegensatz dazu ist der Speicher RAM (Ran- 
dom-Access-Memory) ein Schreib-Lese-Speicher, d.h. ein Direkt- 
Zugriff-Speicher. Hauptspeicher von Personalcomputern sind als 
RAM-Speicher ausgebildet und nehmen das Anwenderprogramm sowie 
die zu verarbeitenden Daten auf. 


1.4.2 Prinzipieller Aufbau eines Mikrocomputers 


Ein Mikro- bzw. Personalcomputer ist im Prinzip genauso aufge- 
baut wie jeder andere Computer (vgl. Abschnitt 1.2.2.1), nur 
sind die Internspeicher als Speicher RAM bzw. ROM ausgebildet 
und die CPU als Mikroprozessor (der Prozessor besteht aus der 
ALU (Arithmetic Logic Unit bzw. Rechenwerk), dem Leitwerk und 
Registern als Speichereinheiten). Ein I/O - Baustein regelt 
den Datenaustausch mit den jeweiligen Ein-/Ausgabegeräten, 
ein Datenbus die Übertragung von Daten (Ziffern, Buchstaben 
ben und Befehlen) und ein Adreßbus die Übertragung von Spei- 
cherplatzadressen. 

Der Mikrocomputer hat Interne Speicher RAM und ROM (als Haupt- 
speicher, Arbeitsspeicher, Memory oder Kurzzeitgedächtnis be- 
zeichnet) einerseits und Externe Speicher wie z.B. eine Dis- 
ketteneinheit andererseits. Deshalb unterscheidet man zwischen 
dem internen und dem externen Datenbus: Über den internen 
Datenbus werden Daten zwischen der ALU, dem Leitwerk, den Re- 
gistern und den Speichern RAM und ROM transportiert, während 
der externe Datenbus die Datenübertragung zu den Externspei- 
chern übernimmt, also zu einer Diskette oder einer Hard Disk. 
Entsprechend gibt es auch einen internen und einen externen 
Adreßbus. | 


| BUS: Datenbus, Adreßbus 














lEingabe/ | <——— PERIPHERIE 
Ispeicher Ausgabe (Externe 
RAM > Speicher) 
— Ö 
-Rechen- Anwender- vorge- Peripherie: Tastatur, Bild- 
(ALU), programm gebene schirm, Diskette, Kassette, 


Leitwerk und Daten Frogramme Festplatte, ... 


Aufbaumodell eines Mikro- bzw. Personalcomputers 
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Wie läuft nun ein Programm ab? Nach dem Start schickt der Mi- 
kroprozessor über den Adreßbus die Adresse des 1. Programmbe- 
fehls an den Speicher, in dem sich das Programm befindet. Dann 
transportiert der Speicher den unter dieser Adresse gefundenen 
Befehl über den Datenbus an den Mikroprozessor. Nach Aus- 
führung des Befehls schickt dieser wiederum die Adresse des 2. 
Programmbefehls an den Speicher usw. 


1.4.3 Typen von Mikrocomputern 


Es gibt Mikroprozesoren mit 8-, 16- und 32-Bit-Struktur. Da 
der Mikroprozessor als "Herz des Computers" die Computereigen- 
schaften entscheidend prägt, unterscheidet man auch für Mikro- 
computer diese drei Typen. 


1.4.3.1 8-Bit-Mikrocomputer 

"Das ist ein 8 - Bit - Computer". Damit ist ein 
Computer mit einem 8-Bit-Mikroprozessor bzw. einer 8-Bit-CPU 
gemeint. Die 8 Bit als Wortbreite des Prozessors kann als ele- 
mentarer Denkinhalt des Computers aufgefaßt werden. Warum? Der 
Datenbus transportiert Daten und Befehle und besteht aus 8 pa- 
rallelen Leitungen. Übertragen wird zeichenweise: der Buch- 
stabe "K" wird im ASCII-Code als 01001011 (1. Leitung 1, 2. 
Leitung 1, 3. Leitung 0, ...) durch den Datenbus gesendet. Mit 
den 8 Bits bzw. den 8 Leitungen des 8-Bit-Datenbus können also 
genau 256 (gleich 2 hoch 8) Zeichen vom Computer unterschieden 
werden. Für die Verarbeitung im ASCII-Code ist diese Zahl von 
256 gerade passend. Es genügt, 256 verschiedene Zeichen unter- 
scheiden zu können. 


Beim Adreßbus sieht dies anders aus: Durch diesen Bus gelangen 
nicht die Daten selbst, sondern deren Hausnummern bzw. Adres- 
sen, unter denen sie im Speicher abgelegt sind (jeder Speicher 
ist fortlaufend durchnumeriert mit Speicherplatz 1, Speicher- 
platz 2, Speicherplatz 3, ...). Damit bestimmt die Anzahl der 
Adreßbus-Leitungen die Anzahl der Speicherplätze, die der Com- 
puter unterscheiden bzw. adressieren kann. Ein 8-Bit-Adreßbus 
kann nur 256 Speicherplätze direkt adressieren. Da dies viel 
zu wenig ist, verwenden die gängigen 8-Bit-Mikroprozessoren in 
der Regel einen Trick: Sie bauen Adressen aus zwei Bytes auf, 
die nacheinander über den Adreßbus zum Hauptspeicher geschickt 
werden. Damit können diese 8-Bit-Computer dann genau 65536 
(2 hoch 16) Zeichen bzw. Bytes anwählen und auch adressieren 
(65536 Bytes = 64 mal 2 hoch 10 = 64 KBytes = kurz 64 K). Dies 
gilt für die beiden weitverbreiteten 8-Bit-CPUs 280 und 6502. 


1.4.3.2 16-Bit-Mikrocomputer 


Die Wortbreite des externen Datenbus bestimmt, ob man einen 
8-Bit-Computer oder aber einen 16-Bit-Computer vor sich hat, 
nicht aber die interne Länge von Registern, die Wortbreite des 
Rechenwerks oder die Befehlslänge. Danach verfügt ein 'echter' 
16 - Bit - Computer über einen internen wie auch 
einen externen 16-Bit-Bus. 
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wenn Personalcomputer wie Sirius 1 oder IBM-PC häufig als 16- 
Bit-Computer bezeichnet werden, dann muß man sich darüber im 
klaren sein, daß die dabei verwendete CPU 8088 zwar 16-Bit-Re- 
gister und Operationen zur Verarbeitung von 16-Bit-Worten auf- 
weist, also einen internen 16-Bit-Bus hat, aber nur einen ex- 
ternen 8-Bit-Bus. Dies bedeutet, daß die 16 Bits der Register 
zum Ausgeben wie zum Laden durch den Datenbus stets halbiert 
bzw. zusammengefügt werden müssen. 

Geräte mit externem 8-Bit-Bus und internem 16-Bit-Bus bezeich- 
nen wir als 8/16 - Bit - Computer. Aufgrund ih- 
rer Stellung zwischen der echten 8-Bit-Struktur und der echten 
16-Bit-Struktur bezeichnet man sie häufig als 'Zwitter'. 


Warum kann ein 16-Bit-Computer nun schneller arbeiten als ein 
8-Bit-Computer? 

Der Bus eines 8-Bit-Computers hat 8 parallele Leitungen. Damit 
können die (2 hoch 8 gleich) 256 Zahlenwerte 0,1,2,...,255 in 
einem Schritt bzw. Zeittakt übermittelt werden. Will man 
größere Zahlen übertragen, müssen diese aufgeteilt und in zwei 
oder mehreren Schritten transportiert werden. Dieses Aufteilen 
kostet natürlich Zeit. 

Dies erübrigt sich beim 16-Bit-Computer, wenn die Zahlenwerte 
0,1,2,...,65535 übermittelt werden sollen. Der 16-Bit-Bus mit 
16 Leitungen erlaubt (2 hoch 16 gleich) 65536 Kombinationen 
bzw. Zahlenwerte, die in e ine m Schritt übermittelt wer- 
den. 

Der Unterschied zwischen 8-Bit-Computern und 16-Bit-Computern 
ist also viel größer als es der Zahlenvergleich "8 zu 16 Bit" 
nahelegt: die Hochrechnungen und damit verbunden der Zahlen- 
vergleich "256 zu 65536 Kombinationen" zeigen den wahren Un- 
terschied zwischen diesen Computertypen. 


1.4.3.3 32-Bit-Mikrocomputer 


Das Leistungsvermögen eines Computers hängt im wesentlichen 
von zwei Größen ab: von der Anzahl der Bits (Wortbreite) und 
von der Schnelligkeit. 32-Bit-Computer weisen bei beiden Grö- 
ßen günstige Werte auf. Zunächst zur Bitanzahl: 

Bei den echten 32-Bit-Computern sind 32 parallele Leitungen im 
Bus zusammengefaßt. Damit vergroßert sich ihr Adreßraum theo- 
retisch auf vier Milliarden Zeichen (vier Gigabytes). Außerdem 
können Computer mit 32-Bit-Struktur binäre Zahlen anstatt auf 
acht Stellen (beim 8-Bit-Mikro) auf 32 Binärstellen genau be- 
arbeiten. Der Befehlsvorrat nimmt ebenfalls zu: die 8-Bit-CPU 
des 6502 versteht 56 Befehle gegenüber den 134 Befehlen des 
16-Bit-Prozessors 8086 und den 230 Befehlen des 32-Bit-Compu- 
ters HP Focus von Hewlett-Packard. 


Die Schnelligkeit eines Computers gibt man in "Millionen In- 
struktionen je Sekunde" (Mips) an. Sie hängt von der Taktfre- 
quenz und von den Abmessungen des Prozessor-Chips ab (je klei- 
ner die Abstände der Leiterbahnen auf der Prozessor-Platine, 
desto höhere Taktfrequenzen und damit Instruktionen je Sekunde 
sind möglich). Die 32-Bit-CPU 32032 soll 1,1 Mips ermöglichen. 
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1.4.4 Generationen von Mikroprozessoren 


Die bislang angeführten Mikroprozessor-Kürzel 280, 6502 sowie 
8088 können leicht in eine etwas übersichtlichere Ordnung ge- 
bracht werden, da es im Grunde nur zwei "Familien" von 8-Bit- 
Prozessoren gibt: die 80-Familie und die 65xx- bzw. 68xx-Fami- 
lie. 1970 erfand Dr. Ted Hoff bei Intel mit dem 4004 den 4-Bit 
Mikroprozessor, 1973 folgte der 8080 als 8-Bit-CPU. Seit 1976 
gelten der 280 von Zilog und der 6502 von Motorola als haupt- 
sächliche Vertreter der nach ihnen benannten Familien. Bereits 
1979 war der 6502 der weltweit meistverkaufte Mikroprozessor. 
Sein Nachfolger 68000 weist als 16-Bit-Mikroprozessor bereits 
einen 16-Bit-Datenbus bei intern 32-Bit-breiten Registern auf, 
er zählt also zu den 'Zwittern' mit 16/32-Struktur. 





Einige weitverbreitete Mikroprozessoren 


Es gibt Personalcomputer, die zwei Mikroprozessoren aufweisen, 
um sowohl auf 8-Bit-Software als auch auf 16-Bit-Software zu- 
greifen zu können. Ein Beispiel: ein 280 als 8-Bit-CPU führt 
Programme für das Betriebssystem CP/M-80 aus und ein 8088 als 
16-Bit-CPU verarbeitet Programme unter CP/M-86. 


1.4.5 Mikrocomputer und ihre Mikroprozessoren 


Im Jahr 1984 verteilen sich die auf dem Markt verwendeten Pro- 
zessoren wie folgt: 

60 Prozent 8-Bit-Prozessoren, 20 Prozent 16-Bit-Prozessoren, 
ein Prozent 32-Bit-Prozessoren und ungefähr je 10 Prozent als 
Zwitter mit 8/16-Bit-Prozessoren bzw. 16/32-Bit-Prozessoren. 
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Bit-Struktur: Prozessor: Mikrocomputer z,B.: 

8 6502 Apple IIe, CBM 8032 

8/16 8088 IBM-PC/XT, IBM PCjr, Sirius 1, 
16 BOB6& Sirius Vicki, ITT 3030, Duet16 
16 28000-858001 Olivetti M20, Zilog 8000 

16/32 MC68000 Apple Lisa, Fortune 32:16 

16/32 NS 16032 Nat.Semi.DB16000, ACORN-BBC 
32 HP Focus Hewlett Packard 9000 


Einige Mikrocomputer und ihre Prozesoren 


1984 besteht eine 32-Bit-Softwarelücke. Entscheidend ist, daß 
32-Bit-Software abwärts-kompatibel gestaltet wird, um auch auf 
Computern mit externem 16-Bit-Bus oder 8-Bit-Bus eingesetzt 
werden zu können. 


1.4.6 EPROM als löschbarer Speicher 


Benutzer von Mikrocomputern werden zuweilen in 'Löter' und in 
'Tipper' eingeteilt: Bauen sich die 'Löter' ihr DV-System aus 
elektronischen Bausteinen hardwaremäßig individuell zusammen, 
so erwerben sich die 'Tipper' einen Computer, um diesen selbst 
zu programmieren (Programm-Tipper) oder gekaufte Software auf 
die eigenen Daten anzuwenden (Daten-Tipper). Die zwei folgen- 
den Entwicklungen verwischen diese Einteilung in 'Löter' sowie 
in 'Tipper' immer mehr: 


Zum einen werden EPROMs als löschbare Speicher immer einfacher 
in der Handhabung, wodurch es auch für die 'Tipper' leichter 
wird, die bislang dem "'Löter' vorbehaltene Arbeiten durchzu- 
führen. 

Ein EPROM (Erasable Programmable Read-Only-Memory) als lösch- 
barer und sodann wieder programmierbarer Festwertspeicher ROM 
ist zwischen den RAM und den ROM einzuordnen. Legt man ihn un- 
ter UV-Licht und bestrahlt den unter einem kleinen Fenster an- 
gebrachten IC, so wird die gespeicherte Information gelöscht. 
Aus diesem Grunde muß ein EPROM stets mit einem undurchsichti- 
gen Fensteraufkleber versehen sein. Umgekehrt können über ein 
Programmiergerät neue Daten und Programme in den EPROM gespei- 
chert werden. Da EPROMs direkt bus-kompatibel sind, d.h. die 
Ausgänge sich direkt an den Datenbus legen lassen, ist dieses 
Vorhaben nicht nur für die 'Löter' interessant. Auch der 'Tip- 
per' kann so seine eigenen Programmentwicklungen leicht in ei- 
nen Festwertspeicher laden. 


Zum anderen können kommerzielle Programme ebenfalls über ein 
EPROM kopiert werden. Ein Beispiel: Der 'Tipper' geht mit sei- 
ner Romox-EPROM-Kartusche in einen Software-Laden, sucht ein 
Programm aus, läßt sich eine Kopie dieses Programms über ein 
im Software-Laden befindliches Gerät in seine EPROM-Kartusche 
laden (Gebühr 5-10 DM), geht nach Hause, steckt die Kartusche 
in seinen Computer und läßt das Programm laufen. Später kann 
er bei Bedarf dann immer wieder ein anderes Programm in den 
EPROM hineinkopieren. 


2 

Einstieg in die 

BASIC- 

- Programmmierung 
des Commodore 64 





2 Einstieg in die BASIC-Programmierung 75 


Auf dem Commodore 64 laufen zahlreiche Programmiersprachen 
wie z.B. Assembler, BASIC, Pascal und LOGO. 

In diesem Buch wenden wir uns ausschließlich der Programmier- 
sprache BASIC zu. 


BASIC stellt keine einheitlich vereinbarte bzw. normierte Pro- 
grammiersprache dar, sondern ist in zahlreichen Versionen ver- 
breitet. 
Die für den Commodore 64 grundlegenden BASIC-Versionen tragen 
die Bezeichnungen: 
-BASIC 2.0 (exakte Bezeichnung "Commodore 64 BASIC V2") 
-BASIC 4.0 (BASIC der Commodore-Serien 4000 und 8000) 
-SIMON's BASIC (Zusatzsprache speziell für den Commodore 64) 


Zu BASIC 2.0: 

Die Standardsprache des Commodore 64 ist das BASIC 2.0, das 
in einem Festwertspeicher ROM untergebracht ist und deshalb 
auch als ROM-BASIC bezeichnet wird. 

Unmittelbar nach dem Einschalten des Commodore 64 steht uns 
dieses ROM-BASIC zur Verfügung. 


Zu BASIC 4.0: 

Bei dieser Programmiersprache handelt es sich um die Sprache, 
die auf den "größeren Brüdern' des Commodore 64 standardmäßig 
verfügbar ist: insbesondere auf Commodore-Mikrocomputern der 
Serien 4000 und 8000. 

Der wichtigste Unterschied zum BASIC 2.0 besteht darin, daß in 
BASIC 4.0 der Zugriff auf Disketten-Dateien sehr komfortabel 
unterstützt wird. 

BASIC 4.0 ist auch für den Commodore 64 als Zusatz verfüg- 
bar - zumeist softwaremäßig, also nicht als ROM-BASIC, sondern 
als Disketten-BASIC. Das bedeutet, daß BASIC 4.0 nicht sofort 
nach dem Einschalten des Commodore 64 da ist, sondern erst von 
einer Systemdiskette in den RAM bzw. Arbeitsspeicher geladen 
werden muß. 


Zu SIMON's BASIC: 

Diese Sprache wurde eigens für den Commodore 64 geschaffen, 
um dessen speizielle Fähigkeiten wie die Grafik- und Musikver- 
arbeitung einfacher nutzen zu können. 

SIMON's BASIC wird überwiegend als Disketten-BASIC verwendet 
und ist deshalb zu Beginn der Arbeit in den RAM zu laden. 


Zur Kompatibilität der drei Sprachen: 

BASIC 2.0 ist aufwärts-kompatibel zu BASIC 4.0 sowie auch zu 
SINOM's BASIC. Das bedeutet, daß ein mit BASIC 2.0 erstelltes 
Programm auch unter BASIC 4.0 und unter SIMON's BASIC läuft, 
d.h. von diesen Sprachinterpretern "'verstanden' wird. 


Zur Bezeichnung der drei BASIC-Versionen in diesem Buch: 

Mit BASIC (ohne Zusatz) bzw. mit Commodore-BASIC ist der Be- 
fehlsvorrat von BASIC 2.0 als Standardsprache des Commodore 64 
gemeint. 

Oder anders ausgedrückt: Mit BASIC werden die Sprachmittel be- 
zeichnet, die -wegen der Aufwärts-Kompatibilität- unter allen 
drei BASIC-Versionen ausführbar sind. 

Programme, die auf e i ne bestimmte Sprache angewiesen sind 
(z.B. Musikprogramme), werden entsprechend mit SIMON's BASIC 
bzw. mit BASIC 4.0 gekennzeichnet, 
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Das vorliegende Kapitel 2 ist in die Abschnitte 2.1 bis 2.5 
untergliedert. 

Wir wollen uns zunächst mit der Tastatur und dem Bildschirm 
des Commodore 64 vertraut machen. Über die Tastatureingabe 
können wir dem Personalcomputer (kurz: PC) etwas mitteilen, 
worauf der PC über die Bildschirmausgabe antwortet. Auf diese 
Weise wirdein direkter Dialog zwischen uns und 
dem PC möglich. In Abschnitt 2.1 wenden wir uns diesem Dialog 
zu. 

In Abschnitt 2.2 erstellen wir das erste Programm 
auf dem Commodore 64 . Als Programmierspache werden wir BASIC 
verwenden, genauer: BASIC 2.0 als das "COMMODORE 64 BASIC v2". 
Unser Programm speichern wir auf Diskette ab. 

In Abschnitt 2.3 beschreiben wir die Anweisungen und Daten der 
Sprache BASIC 2.0 . In den Abschnitten 2.4 und 2.5 wenden wir 
uns den Sprachversionen BASIC 4.0 und SIMON's BASIC zu. 


2.1 Direkter Dialog über Tastatur und Bildschirm 


Nach dem Einschalten des Commodore 64 und des Bildschirmes 
(Fernsehgerät oder Monitor) erscheint am Bildschirm diese Mel- 
dung: 
**&%*% COMMOCORE 64 BASIC V2 *kkxk 

64K RAM SYSTEM 38911 BASIC BYTES FREE 

READY. 

C 
Im Hauptspeicher RAM (Random Access Memory für Direktzugriff- 
Speicher) mit insgesamt ca. 64000 Zeichen (K für Kilo = 1000) 
Speicherplatz stehen uns genau 38911 Zeichen Speicherplatz zur 
Verfügung (für jedes Zeichen ein Byte wie z.B. Byte "01001101" 
für das Zeichen "M"). Wir können also Daten und Programme bis 
zu einer Größe von 38911 Zeichen im Hauptspeicher ablegen. Mit 
dem READY. als dem Bereitschaftszeichen (Prompt-Zeichen) des 
Commodore 64 wird uns gemeldet, daß der PC für weitere Ein- 
gaben bereit ist (ready für bereit). Unter dem READY. blinkt 
der Cursor (oben mit "C" abgekürzt): an der Stelle des 
Cursors erscheint das Zeichen, das wir als nächstes eintippen. 


2.1.1 Rechnen im direkten Dialog 


Wir wollen den Commodore 64 wie ein Tischrechner benutzen und 
100+3 ausrechnen lassen. Dazu tippen wir ein: 
PRINT 100+3 /RET/ 

Nach dem Tippen von 100+3 drücken wir die RETURN-Taste. Die 
Schreibweise /RET/ steht also für "RETURN-Taste einmal kurz 
drücken". Der Commodore 64 antwortet mit dem Ergebnis 103 
und meldet wiederum mit READY. „ daß er für weitere Tastatur- 
eingaben bereit ist. Am Bildschirm steht nun der folgende Dia- 
log: 


PRINT 100+3 /RET/ (=Eingabe von uns) 

103 (=Ausgabe des Computers) 

READY. (=Ausgabe: Bereitschaftszeichen) 
C (=Ausgabe: C für "Cursor blinkt') 


Die PRINT-Anweisung dient hier der Ausgabe von Rechenergebnis- 
sen (print für ausdrucken, ausgeben). 
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Probieren wir einige Rechenoperationen aus: 
PRINT 100.5%-3 J/RET/ (=Eingabe: 100.5 mal -3) 


-301.5 (=Ausgabe einer negativen Zahl) 
READY. 

PRINT 100/3 (=Eingabe: 100 dividiert durch 3) 
33.3333333 (=Ausgabe mit 7 Dezimalstellen) 
READY. 

PRINT 4313 _ (=Eingabe: 4 hoch 3) 

64 (=Ausgabe: 4 mal 4 mal 4) 
READY. 

PRINT 300+3%*4 (=Eingabe: 300 plus (3 mal 4)) 
312 (=Ausgabe: Punkt- vor Strich) 
READY. 

PRINT (300+3)*4 (=Eingabe: 303 mal 4) 

1212 (=Ausgabe: Klammern zuerst) 
READY. 


zahlen werden auf 7 Dezimalstellen genau ausgegeben, also z.B. 
als 33.3333333. Bei Dezimalzahlen wie z.B. bei 100.5 steht der 
Dezimalpunkt, nicht aber das Komma. Geben wir mehrere Rechen- 
zeichen in einer Zeile ein, dann werden die Rechenoperationen 
+ (plus), - (minus), * (mal), / (geteilt), # (hoch) sowie ( ) 
{Setzen von Klammern) in der in der Mathematik üblichen Rang- 
folge ausgeführt. * mit / sowie + mit - sind gleichrangig. 


( ‚ Klammer Die weiter 
— Negative Zahl (Vorzeichen) obenstehende 
} Potenzieren (Hochzeichen) Rechenoperation 
* / Multiplizieren, Dividieren wird vor der 
+ -  Addieren, Subtrahieren untenstehenden 
ausgeführt. 


Rangfolge bei der Ausführung von Rechenoperationen 


zahlen bis zu 9 Stellen gibt unser PC in der normalen Darstel- 
lung aus. Große Zahlen über 10 Stellen und sehr kleine Zahlen 
werden in der Exponentialdarstellung ausgegeben. Hierzu drei 
Beispiele: 

PRINT 300000000 /RET/ (=Eingabe: Zahl mit 9 Stellen) 


300000000 (=Ausgabe unverändert) 

READY. 

PRINT 3000000000 J/RET/ (=Eingabe: Zahl mit 10 Stellen) 
3E+09 (=Ausgabe: 3 mal 10 hoch 9) 
READY 

PRINT 0.0000000003 /RET/(=Eingabe einer kleinen Zahl) 
3E-10 (=Ausgabe: 3 mal 10 hoch -10) 
READY. 


Das "E" steht für Exponent bzw. Hochzahl (3E+09 gleich "3 mal 
10 hoch 9" gleich "eine 3 gefolgt von 9 Nullen"; 3E-10 gleich 
"3 mal 10 hoch -10" gleich "3 mal 1 dividiert durch 3 hoch 10" 
gleich "3 mal 0.0000000001"). 


Das Anweisungswort PRINT läßt sich durch das Fragezeichen ab- 
kürzen. "PRINT 3/6'" können wir damit kürzer als "? 3/6" einge- 
ben. Auch der PC kürzt ab: so gibt er die Zahl 0.5 kurz als .5 
aus. Ein Tip: Geben wir O (Oh) anstelle von O0 (Null) ein, dann 
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verarbeitet der PC dieses Zeichen (Buchstaben O) getrennt. 


? 3/6 (=Eingabe mit ? für PRINT) 

.5 (=Ausgabe: .5 gleich 0.5) 

READY. 

? 30 (=Eingabe: keine Null, sondern O) 
3.0 (=Ausgabe: Zeichen 3 und Zeichen O) 
READY. 


2.1.2 Funktionstasten 


Funktionstasten sind für besondere Aufgaben vorgesehen. Wir 
haben bereits eine Funktionstaste kennengelernt: Mit der Taste 
/RET/ schließen wir die jeweilige Eingabezeile ab. 

wir wollen nun die Funktionstasten /CLR-HOME/, /CRSR/ und 
/INST-DEL/ ausprobieren. 


Bildschirm löschen mit /CLR-HOME/: 

Drücken wir die Taste /CLR-HOME/ rechts oben auf der Tastatur, 
dann bringen wir den Cursor in die linke obere Ecke des Bild- 
schirms. Drücken wir die Tasten /SHIFT/ und /CLR-HOME/ gleich- 
zeitig (wir stellen dies mit /SHIFT/+/CLR-HOME/ dar), so wird 
zusätzlich noch der Bildschirm gelöscht, d.h. sauber gemacht. 


Cursorsteuerung mit /CRSR/: 
Durch Drücken der Tasten 


/CRSRY/ Cursor nach unten 
/SHIFT/+/CRSRNV Cursor nach oben 
/CRSR>/ Cursor nach rechts 
/SHIFT/+/CRSRe/ Cursor nach links 


können wir mit dem Cursor jede Stelle auf dem Bildschirm an- 
steuern. Halten wir die Taste länger gedrückt, dann wiederholt 
sich das Weiterrücken des Cursors automatisch (Auto-Repeat). 
Damit können eine auf dem Bildschirm stehende Eingabe wieder- 
holt zur Ausführung bringen oder korrigieren. Wir geben ein: 


/SHIFT/+/CLR-HOME) (=Eingabe: Bildschirm sauber) 
? 100+3 J/RET/ (=Eingabe) 
103 (=Ausgabe) 
READY. (=Ausgabe) 


Angenommen, wir haben uns vertippt und wünschen 900 statt 100. 
Mit /SHIFT/+/CRSRY/ gehen wir mit dem Cursor hoch bis auf das 
"3", Dann bewegen wir den Cursor mit /CRSR>/ nach rechts bis 
auf die "1". Abschließend tippen wir 9 /RET/ ; auf dem Bild- 
Bildschirm steht nun: 


? 900+3 J/RET/ (=korrigierte Eingabe) 
903 (=Ausgabe) 
READY. 


Die Cursorsteuerung mit /CRSR/ werden wir häufig gebrauchen. 
Bildschirm löschen mit /INST-DEL/: 

wir drücken die Taste /INST-DEL/ rechts oben auf der Tastatur: 
der Bildschirm wird "von hinten aufgerollt' und Zeichen für 
Zeichen bzw. Zeile für Zeile gelöscht (DELete heißt löschen). 
Unser Bildschirm ist leer und der Cursor in der HOME-Position 
links oben. 
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Korrigieren des letzten Zeichens mit /INST-DEL/: 

wir tippen 100+3 ein und drücken dann einmal kurz /INST-DEL/: 
? 100+3 J/INST-DEL/ 

Die zuletzt eingetippte 3 wird gelöscht; wir können 4 /RET/ 

eingeben und erhalten dann 104 als Ergebnis der Korrektur. 

Auf diese Weise kann man mit /INST-DEL/ auch die letzten 2, 3, 

4, ... Zeichen korrigieren. 


Löschen eines Zeichens inmitten einer Zeile mit /INST-DEL/: 
Wir geben 

? 1234556789 
ein. Der Cursor steht hinter der 9 . Wir wollen die versehent- 
lich doppelt getippte 5 löschen. Mit /SHIFT/+/CRSR<e/ steuern 
wir den Cursor nach links auf die zweite 5 , um dann diese 5 
durch einmaliges Drücken von /INST-DEL/ zu löschen. Die Zei- 
chen 6789 werden dadurch um eine Stelle nach links verscho- 
ben. 


Einfügen eines mittleren Zeichens mit /SHIFT/+/INST-DEL/: 
Nach dem Eintippen von 

? 124567890 
steht der Cursor hinter der 0 . Wir wollen die 3 einfügen. Da- 
zu steuern wir den Cursor mit /SHIFT/+/CRSR«/ nach links auf 
die 4. Mit /SHIFT/+/INST-DEL/ schieben wir die Zeichenkette 
4567890 um eine Stelle nach rechts, um dann in die so ent- 
standene Lücke 3 /RET/ einzutippen: Am Bildschirm erscheint 
1234567890 als Antwort. 


2.1.3 Text im direkten Dialog 


Bislang haben wir nur Zahlen -bestehend aus Ziffern, ggf. mit 

Dezimalpunkt und Vorzeichen- eingegeben. Zahlen werden oft als 
numerische Da t en bezeichnet. 

Neben den numerischen Daten kann der Commodore 64 auch Daten 
wie "BASIC-WEGWEISER", "LENA IST HIER." und "RABATT 3%" verar- 
beiten. Sie heißen Text dat en . Der PC erkennt Text- 

daten daran, daß sie stets zwischen Gänsefüßchen " " stehen. 
Welche Buchstaben, Ziffern und/oder Sonderzeichen zwischen " " 
stehen, spielt keine Rolle. 


? "WEGWEISER" (-Eingabe: Text mit 9 Zeichen) 

WEGWEISER (=Ausgabe ohne die Gänsefüßchen) 

READY. 

2." WEGWEISER" (=Eingabe: Text mit 15 Zeichen) 
WEGWEISER (=Ausgabe: zuerst die 6 Blancs) 

READY. 

? "WEGWEISER" (=Eingabe: Text mit 9 Zeichen) 

WEGWEISER (=Ausgabe: Nur Blancs in " '" zählen) 

READY. 

? "BASIC"+"-WEGWEISER" (=Eingabe: "+" verknüpft zwei Texte) 

BASIC-WEGWEISER (=Ausgabe: Ein Text mit 15 Zeichen) 

READY. 

2 "3" + "100" (=Eingabe: "+" verknüpft zwei Texte) 

3100 (=Ausgabe: Text mit 4 Zeichen) 

READY. 

2 "3" / "100" (=Eingabe: Division / unzulässig) 

?TYPE MISMATCH ERROR (=Ausgabe: Fehlermeldung) 


READY. 
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? LEFT$("WEGWEISER",3) (=Eingabe: Links 3 Zeichen nehmen) 
WEG (=Ausgabe: Text mit 3 Zeichen) 
READY. 

- Leerstellen (Blancs, Space) gelten auch als Zeichen und wer- 
den nur berücksichtigt, wenn sie innerhalb der " ' stehen. 

- "100" ist ein Textdatum, kein numerisches Datum. Den 
Versuch zur Division mittels '"/" weist der Commodore 64 mit 
der Fehlermeldung "Falscher Datentyp' ab. 

- "+" bei Text verknüpft, "+" bei numerischen Daten addiert. 

- LEFT$ ist eine spezielle Anweisung zur Textverarbeitung. 


Textdaten werden häufig als Zeichendaten, Zeichenkettendaten 
oder S t rin g s bezeichnet. 

Der Commodore 64 eignet sich zur Verarbeitung von Textdaten 
sowie numerischen Daten gleichermaßen; wir können ihn rechnen 
und auch Briefe schreiben lassen. 


Tippen wir /SHIFT/+/CLR-HOME/ ein, dann ist der Bildschirm ge- 
löscht. Schalten wir den PC aus, dann ist auch der Hauptspei- 
cher des Commodore 64 gelöscht. .... alle Arbeit umsonst, da 
nichts dauerhaft (z.B. auf einer Diskette) gespeichert wurde. 
Wir können Daten abspeichern (z.B. Kundendaten) oder Programme 
(z.B. ein Programm zur Benzinpreisermittlung). Im nächsten Ab- 
schnitt wollen wir ein solches Programm erstellen und abspei- 
chern. 

Sollen Dat en (z.B. Kundendaten) oder ein Programm 
(z.B. ein Programm zur Ermittlung des Benzinpreises) über eine 
längere Zeit aufbewahrt werden, wird man sie außerhalb des RAM 
z.B. auf Kassette, Magnetplatte oder Diskette speichern. 

Auf das Abspeichern eines Programmes auf Diskette gehen wir im 
folgenden Abschnitt ein. Wir werden ein kleines Programm am 
Commodore 64 eingeben und extern speichern. 


2.2 Unser erstes Programm in BASIC 2.0 


Als erstes eigenes Programm wollen wir ein Programm mit dem 
Namen VERBRAUCHI erstellen, d.h. über Tastatur eintippen und 
auf Diskette abspeichern. 
Das Programm VERBRAUCHI1 löst das folgende Problem: 
"Benzinverbrauch beim Pkw: Ermittlung des Verbrauchs 
in Liter/100 km für eine Tankfüllung von 60 Litern". 


2.2.1 Schritt 1: Leeren Hauptspeicher bereitstellen 


Der Hauptspeicher (Arbeitsspeicher) des Commodore 64 befindet 
sich unter der Tastatur. In dieses 'Gedächtnis' des PCs können 
wir -ohne Tricks- immer nur e i n Programm abspeichern bzw. 
eingeben. 
Schalten wir den Commodore 64 ein, so zeigt die Meldung 
*%*%*%% COMMODORE 64 BASIC V2 *%A%*% 

64 K RAM SYSTEM 38911 BASIC BYTES FREE 

READY. 
daß ein leerer Hauptspeicher mit einer Speicherkapazität von 
38911 Zeichen bzw. Bytes bereitgestellt ist. 
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Haben wir dem Commodore 64 eine Arbeit 'befohlen' und befin- 
den sich sich ein Programm oder Daten im Hauptspeicher, müssen 
wir diese Information aus dem Gedächtnis des PCs löschen. Dies 
geschieht durch die Anweisung NEW. Der Dialog 

NEW /RET/ (=Eingabe: Speicherinhalt löschen) 

READY. (=Ausgabe: Hauptspeicher gelöscht) 
stellt uns ebenfalls einen leeren Hauptspeicher bereit. Die 
Anwendung der Anweisung NEW will wohlüberlegt sein: Daten und 
Programme, die zuvor nicht auf Diskette oder Kassette gespei- 
chert wurden, werden gelöscht und sind endgültig verloren. 


2.2.2 Schritt 2: Programm Zeile für Zeile eintippen 


Der Hauptspeicher der Commodore 64 ist jetzt leer. 
Wir wollen das in Abschnitt 3.1.1.1 wiedergegene Programm mit 
dem Namen VERBRAUCH]I eintippen: Zeile für Zeile, wobei am Ende 
jeder Zeile die RETURN-Taste gedrückt wird (abgekürzt: /RET/). 
Wir tippen ein: 

10 LET T = 60 /RET/ 

20 PRINT "EINGABE: GEFAHRENE KM" /RET/ 

30 INPUT K /RET/ 
Dann tippen wir ein: 

LIST /RET/ 
Der Commodore 64 LISTet die drei Programmzeilen 10-30 auf, 
wie er sie im Hauptspeicher abgespeichert hat. Der LIST-Befehl 
dient uns so zur Kontrolle. Sind die drei Programmanweisungen 
wie gewünscht abgespeichert? Falls nein: bitte nochmals tippen 
10 LETT = ... usw. Falls ja: Wir tippen die anderen vier Pro- 
grammzeilen 40-70 ein: 

40 LET D = 100 * T / K /RET/ 

50 PRINT "AUSGABE: LITER/100 KM" /RET/ 

60 PRINT D /RET/ 

70 END /RET/ 
Wenn wir nun erneut den Befehl 

LIST /RET/ 
eintippen, so müsste die komplette Anweisungsfolge Zeile 10-70 
am Bildschirm erscheinen und dann wieder das READY.-Zeichen 
als das Bereitschaftszeichen des Commodore-BASIC. 


2.2.3 Schritt 3: Programm mit RUN ausführen lassen 


Zur Ausführung des nun im Hauptspeicher RAM befindlichen Pro- 
gramms tippen wir den Befehl 

RUN /RET/ (=Eingabe von uns) 
ein. Unser Programm wird jetzt ausgeführt, wie es dem Commo- 
dore 64 durch die 7 Anweisungen in den Zeilen 10-70 befohlen 
wird. 
Tippen wir z.B. 600 km ein, so zeigt sich uns folgender Dialog 
(auch Ausführung, Dialogprotokoll oder Programmlauf genannt): 


RUN /RET/ (=Eingabe von uns) 
EINGABE: GEFAHRENE KM (=Ausgabe des Computers) 
? 600 (=Eingabe von uns) 
AUSGABE: LITER/100 KM (=Ausgabe des Computers) 
10 (=Ausgabe des Computers) 


READY. (=Ausgabe des Computers) 
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Die Gegenüberstellung von Codierung und Ausführung zu unserem 
Programm zeigt, daß die Zeilennummern 10 - 70, die Anweisungs- 
worte LET (berechne), PRINT (gib aus), INPUT (gib ein) u. END, 
die Gänsefüßchen und die gesamten LET-Anweisungen beim Ausfüh- 
rungsprotokoll nicht am Bildschirm erscheinen. 

Wir können das im RAM gespeicherte Programm jetzt wiederholt 
mittels RUN /RET/ laufen lassen: mit jeweils anderen Zahlen, 
aber stets in der gleichen Anweisungsfolge Zeile 10,20,30, ... 
Ein Hinweis: Der exakte Programmablauf wird in Abschnitt 3.1.1 
erklärt. 


Im RAM befinden sich e i n Programm namens VERBRAUCHI sowie 
die drei Variablen namens T, K und D. Das Programm stellen wir 
uns als große Schachtel mit einer Anweisungsfolge als Inhalt 
bzw. Wert (7 Anweisungen) vor, die Variablen als Schachteln 
mit Zahlen als Inhalt. Die Abbildung zeigt die drei Speicher- 
zustände, in die wir den RAM nach und nach versetzt haben. Da- 
bei ist festzuhalten: in den RAM können wir jeweils nur ein 
Programm speichern, aber mehrere Variablen. 


RAM nach Eintippen RAM nach Eintippen RAM nach Ausführung 
des NEW-Befehls: von VERBRAUCH]: von VERBRAUCH]: 










Leer: Speicher- VERBRAUCH]I VERBRAUCH] 
plätze weder mit 
| Anweisungen (Pro- 
gramm) noch mit 
| Daten (Variablen) 


belegt. 





Weder (Anwender)- Ein Programm Ein Programm und 
Programm noch Daten drei Variablen 


Speicherbelegung des Hauptspeichers (RAM) zu drei Zeitpunkten 


Über die PRINT-Anweisung können wir uns die derzeitigen Werte 
der Variablen im direkten Dialog zeigen lassen: 


PRINT T /RET/ (=Eingabe von uns) 
60 (=Ausgabe des Computers) 
READY. (=Ausgabe des Computers) 
PRINT K,D /RET/ (=Eingabe von uns) 
600 10 (=Ausgabe des Computers) 
READY. (=Ausgabe des Computers) 


In T ist 60 gespeichert und in K bzw. in D genau 600 bzw. 10. 
Dabei geben wir PRINT ohne vorhergehende Zeilennummern ein, um 
uns die Variablenwerte direkt PRINTen bzw. ausgeben zu lassen. 
Da die PRINT-Anweisung nun direkt ausgeführt wird, spricht man 
von der direkten Betriebsart oder (wie im 


2.2 Unser erstes Programm in BASIC 2.0 83 


vorhergehenden Abschnitt ) vm direkten Dialoog. 
Geben wir am Zeilenanfang eine Zeilennummer ein, dann wählen 
wir damit die indirekte Betriebsart bzw. 
den programmgesteuerten Dialog. Die 
Anweisungen hinter den Zeilennummern werden gespeichert und 
später nach dem Eintippen von RUN gemäß ihrer Numerierung zur 
Ausführung gebracht. 


Betriebsart 

DIREKTER DIALOG PROGRAMMGESTEUERTER DIALOG 
(Direktausfuhrung, (Programmausführung, 

direkte Betriebsart, indirekte Betriebsart, 
Direkt-Modus, Programm-Modus, 
Direktanweisung) Programmanweisung) 
Eingabe von Anweisungen Eingabe von Anweisungen mit 
direkt. vorangestellten Zeilennummern. 
Ausführung sofort. Ausführung erst später 


mittels RUN. 
Beispiel: PRINT D Beispiel: 60 PRINT D 


Direkter und programmgesteuerter Dialog 


2.2.4 Schritt 4: Programme mit SAVE auf Diskette speichern 


Bei Abschalten des Stromes (bitte nicht tun!) wäre unser Pro- 
gramm verloren. Wir speichern deshalb eine Kopie des Programms 
auf Diskette ab. 


wir schalten das Diskettenlaufwerk (Floppy) "VC1540, VC 1541" 
ein und legen eine beschriebene Diskette ein. Der Einfachheit 
halber benutzen wir die der "Floppy 1541" beigefügte Diskette 
TEST/DEMO, die noch genügend Speicherplatz frei hat (den auf- 
geklebten Schreibschutz (Silberpapierstreifen) vor dem Einle- 
gen entfernen). 

Jetzt geben wir die folgende SAVE-Anweisung zum Speichern des 
Programms VERBRAUCH ein: 


SAVE "VERBRAUCH1",8 /RET/ (=Eingabe von uns) 
SAVING VERBRAUCHI (=Ausgabe: es wird gespeichert) 
READY. (=Ausgabe: Bestätigung) 


Nach Erlöschen der Hinweis-Lampe am Diskettenlaufwerk ist eine 
Kopie des im Internspeicher RAM befindlichen Programms unter 
dem Namen VERBRAUCHI auf der Diskette als Externspeicher dau- 
erhaft gespeichert. Schalten wir nun den Strom ab, so geht nur 
das im RAM befindliche Programmoriginal verloren, nicht jedoch 
die Kopie auf der Diskette (die ja geSAVEd bzw. gerettet ist). 


Hinter dem Befehlswort SAVE wird der Programmname (maximal 16 
Zeichen lang) und die 8 als Geräteadresse der Floppy angege- 
ben. 
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Über den folgenden Dialog gibt uns der Commodore 64 ein In- 
haltsverzeichnis (Directory) aller gerade auf der eingelegten 
Diskette gespeicherten Programme aus: 


LOAD '"$",8 J/RET/ (=Eingabe: Directory laden) 
SEARCHING FOR $ (=Ausgabe: Directory wird gesucht) 
READY. (=Ausgabe: Directory jetzt im RAM) 
LIST /RET/ (=Eingabe: Directory auflisten) 

0 "1541 TEST/DEMO "2X 2A Inhaltsverzeichnis für: 

13 "HOW TO USE" PRG - Diskettenlaufwerk 1541 

5 "HOW PART TWO"" PRG - Diskette TEST/DEMO 

4 "vVIC-20 WEDGE" PRG - Mehrere Programme (PRG) 

. weitere Programme ... 

13 "RANDOM FILE" PRG 

1 "VERBRAUCH!"" PRG 

557 BLOCKS FREE 

READY. 


Die erste Zeile des Inhaltsverzeichnisses gibt in negativer 
Schrift (invers) den Namen der Diskette mit TEST/DEMO und ihre 
Identifikation (ID) mit 2X an. 

Nach den Programmen "HOW TO USE", "HOW PART TWO", ... ist das 
Programm "VERBRAUCHI!" jetzt als letztes auf der Diskette ge- 
speichert. Es belegt nur einen Block Speicherplatz (ist also 
sehr klein). Auf der Diskette sind noch 557 Blöcke zur Spei- 
cherung weiterer Programme (PRG) frei. 


2.2.5 Schritt 5: Programm mit LOAD von Diskette laden 


Zur Zeit befindet sich das Inhaltsverzeichnis bzw. Directory 
der Diskette im Hauptspeicher RAM des Commodore 64 . Wir wol- 
len nochmals mit dem Programm VERBRAUCH]I1 arbeiten. Dazu tippen 
wir die LOAD-Anweisung ein: 


LOAD "VERBRAUCH1",8 J/RET/ (=Eingabe von uns) 
SEARCHING FOR VERBRAUCHI (=Ausgabe des Commodore 64) 
READY. 


Diese Anweisung sucht das Programm VERBRAUCHI1 auf der Diskette 
und lädt eine Kopie davon in den RAM. Das noch im RAM stehende 
Inhaltsverzeichnis wird durch LOAD dabei überschrieben und 
somit zerstört. 

Genau dieses 'Zerstören' der gerade im Hauptspeicher befindli- 
chen Information ist so "'gefährlich' bei der LOAD-Anweisung. 
Vor dem Eintippen von LOAD ist also stets zu bedenken, ob die 
gerade im Hauptspeicher stehende Information (Programm sowie 
Daten) nicht noch mittels SAVE gerettet bzw. 'geSAVEd' werden 
muß. 

Vergißt man die Geräteadresse 8 der Disketteneinheit, dann er- 
gibt sich dieser Dialog: 


LOAD "VERBRAUCH1" /RET/ (=Eingabe von uns: 8 vergessen) 
PRESS PLAY ON TAPE (=Ausgabe des Commodore) 
/RUN-STOP/ (=Eingabe von uns: Stoppen) 

? BREAK ERROR (=Ausgabe: Fehlermeldung) 


READY. (=Ausgabe) 
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Beim Fehlen der Gerätenummer nimmt das System automatisch die 
Gerätenummer 1 des Bandgerätes (Kassette) an. Durch /RUN-STOP/ 
(Taste links) brechen wir den Ladevorgang von der Kassette ab. 


Das Programm VERBRAUCHI1 steht uns im RAM wieder zur Verfügung: 
mit LIST können wir es auflisten und mit RUN laufen lassen. 


2.2.6 Schritt 6: Programm geändert auf Diskette speichern 


Wir wollen das Programm VERBRAUCHI durch eine PRINT-Anweisung 
erweitern und das abgeänderte Programm unter demselben Namen 
erneut auf Diskette speichern. 
Wir geben ein: 

/SHIFT/+/CLR-HOME/ 

LIST /RET/ 
Das Listing von VERBRAUCHI steht oben am Bildschirm. Nun geben 
wir die zusätzliche Anweisung 

15 PRINT "DURCHSCHNITTSVERBRAUCH ERMITTELN" /RET/ 
ein. Wir testen das Programm mit RUN. Wie die Eingabe von LIST 
zeigt, wurde die neue Anweisung mit Zeilennummer 15 wie beab- 
sichtigt zwischen die Zeilen 10 und 30 angeordnet. 


Durch Eingabe von 


SAVE "®:VERBRAUCH1",8 (=Eingabe: Klammeraffe für Über- 
SAVING @: VERBRAUCHI (=Ausgabe) schreiben) 
READY. 


speichern wir das Programm erneut ab. SAVE findet auf Diskette 
bereits ein Programm namens VERBRAUCHI vor. Der Klammeraffe ® 
(Zeichen "at sign') vor dem Programmnamen sorgt dafür, daß das 
Programm überschrieben, d.h. die 'alte' Programmversion zer- 
stört und das 'neue' Programm dafür abgespeichert wird. 

Ein wichtiger Hinweis: Vergessen wir den Klammeraffen ® , dann 
meldet sich der PC ebenfalls wieder mit READY. ; das Programm 
wurde jedoch n i ch t erneut auf Diskette gespeichert. 


2.2.7 Eigentlich Schritt 0: Diskette formatieren 


wir sind bislang in diesen sechs Schritten vorgegangen: 


Schritt 0: Diskette formatieren 

Schritt 1: Leeren Hauptspeicher bereitstellen 
Schritt 2: Programm Zeile für Zeile eintippen 
Schritt 3: Programm mit RUN ausführen lassen 
Schritt 4: Programm mit SAVE auf Diskette speichern 
Schritt 5: Programm mit LOAD von Diskette laden. 
Schritt 6: Programm geändert auf Diskette speichern 


Bei den Schritten 4 bis 6 haben wir mit einer Diskette gear- 
gearbeitet: der Einfachheit halber haben wir die zum Commodore 
mitgelieferte TEST/DEMO-Diskette benutzt. Nun wollen wir eine 
neue Diskette verwenden. 


Das Laufwerk "Commodore VC 1541" arbeitet mit 5.25"-Disketten, 
auf die es 35 Spuren mit einfacher Schreibdichte schreibt. Es 
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genügen somit Disketten "ss/sd,35 Tracks" oder "ss/dd, 1D, 40 
Tracks, 48 TPI" (ss=single sided, sd=single density, dd=double 
density). 

Solche Disketten können wir kaufen - leer, unbespielt und für 
PCs unterschiedlicher Fabrikate einsetzbar. Bevor wir auf die- 
se Disketten unsere Programme speichern können, müssen wir sie 
in eine Fo rm bringen (Einteilung der Diskettenoberfläche 
in 35 Spuren/Tracks mit jeweils 17 bis 21 Sektoren), die genau 
dem Betriebssystem des Commodore 64 entspricht. Das "in Form 
bringen der Diskette' nennt man Formatieren . 


Als Diskettenname wählen wir "WEGWEISER C64". Wir schalten das 
Laufwerk ein und legen eine leere Diskette ein. Dann geben wir 
im direkten Dialog folgende Befehle ein: 


OPEN 1,8,15 J/RET/ (=Eingabe Kanal Öffnen) 
READY. (=Ausgabe) 
PRINT#1,"NEW:WEGWEISER C64,01" /RET/ (=Eingabe NEW-Befehl) 
READY. (=Ausgabe) 

CLOSE 1 (=Eingabe) 

READY. (=Ausgabe) 


Das Diskettenlaufwerk ist ungefähr 1 1/4 Minuten mit dem For- 
matieren beschäftigt. Dabei ist 35 mal ein '"Knacken' zu hören, 
da 35 kreisrunde Spuren geschrieben werden und der Schreib-/ 
Lesekopf 35 mal bewegt wird. 

Der NEW-Befehl formatiert eine Diskette namens "WEGWEISER C64" 
mit der Identifikation (ID) 01. 


Systembefehle wie z.B. der NEW-Befehl werden stets mit dem Be- 
fehl PRINT# über einen Befehlskanal übermittelt. In unserem 
Fall spricht PRINT#1 den Kanal 1 an: 
Vor dem Formatieren mittels NEW muß stets ein Kanal mit 
OPEN 1,8,15 J/RET/ 
eröffnet werden, über den sich dann der gesamte Datenverkehr 
zwischen dem Commodore 64 und der Floppy 1541 abwickelt. 
Nach dem Formatieren ist der Kanal wieder mit | 
CLOSE 1 
zu schließen (1=logische Dateinummer, wählbar zwischen 1-127; 
8=-Gerätenummer der Floppy fest; 15=Sekundäradresse für Daten- 
und Befehlskanal fest). Öffnen wir den Kanal mit OPEN 2,8,15, 
dann ist er mit CLOSE 2 zu schließen. 


Wir lassen uns nun das Inhaltsverzeichnis der neuen Diskette 
zeigen: 
LOAD "$",8 J/RET/ (=Eingabe: Directory $ laden) 
SEARCHING FOR $ (=Ausgabe ) 
LOADING (=Ausgabe: Directory geladen) 
READY. 
LIST J/RET/ (=Eingabe: Directory auflisten) 


0 "WEGWEISER C64 "01 2A 

664 BLOCKS FREE 

READY. 
Auf der Diskette WEGWEISER C64 mit der Identifikation 01 ist 
noch kein Programm gespeichert. Alle 664 Blöcke sind frei. 


Wie können wir das Programm VERBRAUCHI jetzt von der Diskette 
TEST/DEMO auf unsere Diskette WEGWEISER C64 umspeichern bzw. 
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kopieren? Wir gehen in vier Schritten wie folgt vor: 
1) Diskette TEST/DEMO einlegen. 
2) Programm VERBRAUCHI laden: 
LOAD "VERBRAUCH1",8 J/RET/ 
SEARCHING FOR VERBRAUCHI 
LOADING 
READY. 
3) Diskette WEGWEISER C64 einlegen. 
4) Programm VERBRAUCHI speichern: 
SAVE "VERBRAUCH1",8 J/RET/ 
SAVING VERBRAUCHI 
READY. 
4) Inhaltsverzeichnis prüfen: 
LOAD "$",8 J/RET/ 
SEARCHING FOR $ 
LOADING 
READY. 
LIST 


0 "WEGWEISER C64 "01 2A 

1 "VERBRAUCHI PRG 

663 BLOCKS FREE 

READY. 
Unsere Anwenderdiskette WEGWEISER C64 enthält somit ein Pro- 
gramm. 


Ein Hinweis zur Identifikation ID: Wir vergeben für jede neue 
Diskette eine andere ID (jeweils zweistellig: z.B. 01, 02, 03, 
04, ...). Dies hat den Vorteil, daß wir uns bei einem Wechsel 
der Diskette nicht um die Initialisierung kün- 
mern müssen: 

- Initialisieren (Anfang setzen) heißt: Das Verzeichnis der 
freien und belegten Blöcke BAM (Block Availabiity Map) von 
Diskette in den Speicher des Laufwerkes einlesen. 

- Bei unterschiedlichen IDs der Disketten initialisiert das 
System automatisch. 

Im obigen Beispiel: Disketten TEST/DEMO und WEGWEISER C64 
mit den IDs 2X und 01. 
- Bei gleichen IDs müssen wir über den Systembefehl 
PRINT#1 ,"INITIALIZE" /RET/ 
das Initialisieren im direkten Dialog selbst vornehmen. 


Bei neueren Versionen des Commodore-DOS muß sich der Benutzer 
nicht mehr um die Initialisierung kümmern. 
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2.3 Alle Befehle der Standardsprache BASIC 2.0 an Beispielen 


Die folgende Kurzbeschreibung orientiert sich an Beispielen. 
Die gilt für die Beschreibung der Daten wie der Anweisungen, 
die die Programmiersprache "Commodore 64 BASIC V2" dem Anwen- 
der bereitstellt. | 

Wir beziehen uns dabei auf die allgemeine Darstellung von Da- 
tenstrukturen und Programmstrukturen in Abschnitt 1.3. 


"Commodore 64 Basic V2" bzw. BASIC 2.0 isst aufwärts - 
kompat ibe 1 zu BASIC 4.0 und zu SIMON's BASIC. 

Das bedeutet: Alle im folgenden an einfachen Beispielen darge- 
stellten Befehle können wir auch unter BASIC 4.0 sowie unter 
SIMON's BASIC verwenden. 


2.3.1 Konstante und variable Daten 
2.3.1.1 Konstante 


BASIC kennt die Datentypen INTEGER (Ganzzahl), REAL (Dezimal- 
zahl) und STRING (Zeichenkette bzw. Text). Entsprechend gibt 
es auch drei Typen von Konstanten, also drei Typen 
von Daten, die während des Programmlaufes unverändert bleiben: 
INTEGER-Konstante, REAL-Konstante und STRING-Konstante. 


Datentyp: Kennzeichen: Speicher- Beispiele: 
platz: 

INTEGER -32767 bis 32767 4 Bytes 321, -10000, -1 

REAL Größer als INTEGER 4 Bytes 999182 -111111 
oder E (Exponent) 3,1E8B = 3.1%*10#8 
oder Punkt mit 5543.11 ‚752 
max. 7 Stellen 0.00002 -0,097 

STRING Max. 255 Zeichen; bis 255. "DM-BETRAG" N" 
zwischen " ' Bytes "12" "Ergebnis" 


Numerische Konstante (INTEGER,REAL) und Textkonstante (STRING) 


Zahlen vom Datentyp REAL werden mit 7 Dezimalstellen verarbei- 
tet. Vor der Ausführung von Rechenoperationen werden Zahlen 
vom Datentyp INTEGER in den Datentyp REAL verwandelt. Oder an- 
ders ausgedrückt: INTEGER-Zahlen sind eine Teilmenge der REAL- 
zahlen. 
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2.3.1.2 Variable für einfache Datentypen 


Jede Variable hat einen Namen, einen Datentyp und einen Wert, 
der sich ändern kann und somit variabel ist (Abschnitt 1.3.4). 
Wie für die Konstanten unterscheidet BASIC auch für die Vari- 
ablen die drei Typen INTEGER, REAL und STRING. 


Datentyp: Typzeichen: Beispiele für Variablennamen: 
INTEGER % I% ZINSTEILER% A33% SATZNR®% 
REAL ohne DM SUMME## AI B18554 A33 
STRING $ NAME$ A.1$ BEZEICHNUNG$ FILE$ 


Numerische Variablen (INTEGER,REAL) und Textvariablen (STRING) 


Geben wir keines der beiden Datentypzeichen % und $ am Ende 
eines Variablennamens an, dann nimmt BASIC automatisch REAL 
als Datentyp an. 

Außer dem Typzeichen können wir unsere Variablennamen beliebig 
wählen, vorausgesetzt, sie unterscheiden sich in den ersten 2 
Zeichen. Dabei muß der Name natürlich mit einem Buchstaben be- 
ginnen. Variablennamen können bis zu 255 Zeichen lang sein. 
Die Namen MEHRWERTSTEUER, ME7715, ME7715$, MELDUNG3, MELDUNG% 
und MEERESTIEFE werden somit in BASIC als ME, ME, ME$, ME, ME% 
und ME unterschieden. Viermal taucht der Variablenname ME auf; 
solche Überschneidungen sind in jedem Fall zu vermeiden. Also 
beachten: Variablennamen müssen sich in den erstenbeiden 
Zeichen u nd dem Datentypzeichen unterscheiden. 


BASIC verfügt über reserviert e NWorte wie LIST, FN, 
GOSUB, TO, ST oder PRINT. In Abschnitt 2.1.3 sind diese Worte 
für Anweisungen usw. wiedergegeben. Verwenden wir solche Worte 
als Variablennamen, führt dies zwangsläufig zu Fehlern. Wo- 
her soll BASIC auch wissen, wann z.B. LIST als Variablenname 
zu gelten hat und wann als Befehl zum Auflisten des Programms? 


Das Einrichten von Variablen heißt Vereinbarung 
(vgl. Abschnitt 1.3.4.2). In BASIC gibt es nur die sogenannte 
implizite Vereinbarung . Dabei teilt man 
durch Angabe des Typzeichens den Datentyp mit. So soll z.B. M$ 
STRINGs aufnehmen können (Typzeichen $), M% aber INTEGER-Zah- 
len (Typzeichen $%). 

In den Programmbeispielen von Abschnitt 3 weisen wir über REM- 
Anweisungen ausdrücklich auf den gewählten Datentyp hin. Damit 
erreichen wir fast eine ex p 1 ii zi te Vereinbarungsform. 


2.3.1.3 Variable für Datenstrukturen 


Bei den Variablen für einfache Datentypen wird jeweils nur 
e in Datum als Variable gespeichert, bei den Variablen für 
strukturierte Datentypen bzw. Datenstrukturen sind es mehrere 
Daten (vgl. Abschnitt 1.3.2). 

In BASIC stehen uns als Datenstrukturen ARRAYs bzw. Tabellen 
sowie FILEs bzw. Dateien zur Verfügung. 
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Arrays (oft auch Tabellen, Felder, Bereiche, Listen oder 
Vektoren/Matrizen genannt) umfassen mehrere Elemente vom glei- 
chen Datentyp. Entsprechend können INTEGER-ARRAYs, REAL-ARRAYS 
und STRING-ARRAYs vereinbart werden. 

Zur Vereinbarung der Dimension dient die DIM-Anweisung. 


100 DIM L&(30) 1-dimensionaler INTEGER-ARRAY zur Auf- 
nahme von 31 Ganzzahlen an den Stellen 
0,1,2,3r=-=»«r30. Name des Arrays: L%. 


100 DIM S(2,6) 2-dimensionaler REAL-ARRAY zu 3 Zeilen 
und 7 Spalten, d.h. 21 Elementen. 


100 DIM B$(2,3,4) 3-dimensionaler STRING-ARRAY mit 3%4%#5 
=60 Elementen zu je 255 Zeichen max. 


100 DIM M(A$®) 1-dimensionaler REAL-ARRAY mit A% Ele- 
menten; Index -hier A%- stets INTEGER. 


INTEGER-ARRAY, REAL-ARRAY und STRING-ARRAY 
In Abschnitt 3.7 gehen wir näher auf Arrays ein. 


zum F i le (Datei) als zweiter Datenstruktur. 

- BASIC 2.0 unterstützt direkt nur die sequentielle Datei. In 
Abschnitt 3.8.1 gehen wir auf diesen Dateityp ein. 

- Die Direktzugriff-Datei bzw. REL-Datei (für RELative Datei) 
ist in BASIC 2.0 'über Umwege' ebenfalls programmierbar. Wir 
zeigen dies in Abschnitt 3.8.4. 

- Auf die Dateiverarbeitung mit BASIC 4.0 
gehen wir in den Abschnitten 3.8.2 und 3.8.3 ein. 


2.3.2 Anweisungen und Funktionen 


Im folgenden werden die wichtigsten Anweisungen und Funktionen 
der Programmiersprache BASIC zusammengefaßt. 
Genaue Erklärungen zu den Befehlen finden Sie in Abschnitt 3. 


2.3.2.1 Einfache Anweisungen 


CLEAR (Löschen von Variablenwerten): 
CLEAR: Alle Variablen INTEGER, REAL und STRING erhalten die 
Werte 0 bzw. "" (Leerstring). 


CM D (Ausgaben z.B. zum Drucker statt zum Monitor senden): 
OPEN 1,4: CMD1: LIST: PRINT#1: CLOSE Kanal zum Drucker (Ge- 
rät 4) öffnen, Programm listen, Kanal schließen). 


CO NT (Ausführung fortsetzen): 

CONT Ausführung fortsetzen mit der Zeile der Unterbrechung. 
Unterbrechung durch /RUN-STOP/ oder durch Anweisungen 
STOP bzw. END. 
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eD A TA (Daten im Programm speichern): 
100 DATA 22,"DM/STD" Daten programmintern in DATA speichern 
110 READ D,D$ und z.B. nach D (22) und D$ ("DM/STD") lesen. 


eDEF FN ... (Definieren einer Funktion): 
100 DEF FNDOPPEL(X)=X*2 Definition der Funktion FNDOPPEL, die 
110 PRINT FNDOPPEL(A) bei Aufruf z.B. den Wert A verdoppelt. 


eD I M (Dimensionieren von Arrays): 
100 DIM M(3,8) REAL-Array M mit 3 Zeilen/8 Spalten und zwei 
110 DIM A$(9),B$(9) STRING-Arrays (9 Stellen) dimensionieren. 


eE N D (Beenden der Programmausführung): 
END Ausführung des Programms beenden. 


eFOR - NEXT (Zählerschleife): 
100 FOR I=1 TO 10 STEP 2 zählerschleife gibt Werte 1,3,5,7,9 
110 PRINT I : NEXT I der Laufvariablen I aus. 
eG E T (Einzelnes Zeichen von Tastatur lesen): 
100 GET E$: IF E$="" GOTO 100 Wenn irgendeine Taste gedrückt 
110 ... wird, dann Programmfortsetzung mit Folgezeile 110. 
eGOSUB - RETURN (Unterprogrammsteuerung): 
100 GOSUB 2000 Unterprogramm ab Zeile 2000 aufrufen, ausfüh- 
110 ... ren und mit RETURN in Folgezeile 110 zurück. 


eG O0 TO (Unbedingte Verzweigung): 
100 GOTO 350 Von Zeile 100 (unbedingt) zu 350 verzweigen. 


elF - TH EN (Bedingte Verzweigung): 
100 IF G=3 GOTO 350 Wenn G=3, dann nach 350 verzweigen. 
100 IF G=3 THEN 350 Verzweigung wie mit GOTO. 
100 IF A$="JA" THEN PRINT "Richtig' Ausgabe im Fall "JA". 


G= 
G= 
A$ 
el N PU T (Eingabe über Tastatur): 

100 INPUT A Auf Tastatureingabe warten und diese A zuweisen. 


100 INPUT "Welche Zahl";A Eingabeaufforderung zusätzlich. 
100 INPUT N,D,W$ Zwei Zahlen und ein STRING als Eingabe. 


eL ET (Wertzuweisung): 
100 LET K=5 Den konstanten Wert 5 der Variablen K zuweisen. 
100 LET K=K+5 Den derzeitigen Wert von K um 5 erhöhen. 
100 LET Z=K*P*T/(100*360) Wert berechnen und nach Z zuweisen. 


eı IS T (Auflisten der BASIC-Codierung): 
LIST Alle Zeilen des im RAM befindlichen Programms auflisten. 
LIST 170 Nur die Zeile 170 auflisten. 
LIST 50- LIST -50 LIST 50-300 Auflisten von, bis, von-bis. 


eN E W (Löschen des Hauptspeichers): 
NEW Im RAM befindliches Programm und Variablen löschen. 


eoON - GOS UB (Fallabfrage mit Unterprogrammaufruf): 
100 ON W GOSUB 1000, 2000,3000 Für W=1 in Unterprogramm 1000, 
110 ... für W=2 nach 2000 und für W=3 nach 3000 verzweigen. 
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eON - GO TO (Fallabfrage mit Verzweigung): 
100 ON E GOTO 10,30,70 Für E=1 nach 10 verzweigen, für E=2 
110 ... nach 30, für E=3 nach 70, für E=0 nach Folgezeile. 


eP EEK (Speicherplatz direkt lesen): 
100 PRINT PEEK(25386) Inhalt von Speicherplatz 25386 zeigen. 


ePO KE (Speicherplatz direkt beschreiben): 
100 POKE 25386, 255 Wert 255 nach Speicherplatz 25386 bringen. 


epR INT (Ausgabe auf Bildschirm): 
100 PRINT A,B,C Ausgabe der Werte von Variable A, B und C. 
100 PRINT DM,'"'DM" Wert der Variablen DM und Text "DM" zeigen. 
100 PRINT DM,"DM"; Das ; am Ende unterdrückt das RETURN. 


eR EA D (Lesen von Daten aus DATA-Zeile): 
100 READ T Naechsten Wert aus DATA in Variable T einlesen. 


100 READ T,A$,V(I) Reihenfolge REAL, STRING, REAL in DATA. 
eR EM (Bemerkungen in BASIC-Codierung einfügen): 
100 REM AUTOR: X.HOFFMAN Bemerkung (Remark) bei LIST zeigen, 
eRES TORE (Lesezeiger auf Position 1 zurücksetzen): 
100 READ X,Y,Z Lesezeiger der DATA-Zeile durch RESTORE auf 
110 RESTORE Position 1 zurücksetzen, um erneut mit READ 
120 READ D,E,F lesen zu können. 
eR UN (Ausführen eines Programms im Hauptspeicher): 


RUN Das gerade im RAM befindliche Programm ausführen. 
RUN 600 Bei der Ausführung mit Programmzeile 600 beginnen. 


es TOP (Abbrechen der Programmausführung): 
100 STOP Abbrechen und die Meldung "BREAK IN 100" ausgeben. 


es YS (Sprung in ein Maschinenprogramm) 
SYS(30215) ruft ein Assembler-Programm auf, dessen Anfangs- 
adresse in Speicherplatz 30215 liegt. 


ewWA IT (Warten, bis eine angegebene Speicherstelle einen 
bestimmten Wert hat) 


2.3.2.2 Funktionen 


e ABS(X) (Absolutwert von Zahl X): 


100 PRINT ABS(-5) Absolutwert von -5 ist 5. 
e ASC(S$) (ASCII-Codezahl von String S$): 

100 PRINT ASC('"MUELLER") ASCII-Codezahl von "M" ist 77. 
e ATN(X) (Arcustangens von Zahl X angeben) 


e CHR$(A) (Zeichen (character) für ASCII-Codezahl A): 
100 PRINT CHR$(77) Zeichen (String) mit Codezahl 77 ist "M". 


e COS(X) (Cosinus von Zahl X angeben) 


2.3 Alle Befehle der Standardsprache BASIC 2.0 93 


e EXP(X) (Exponentialfunktion für e): 
100 PRINT EXP(1) e hoch 1 ergibt 2.71828183. 


e FRE(0) (Für Anwender verfügbarer Speicherplatz (0=dumy)): 
100 PRINT FRE(O) Frei verfügbar z.B. 12652 Zeichen. 


e INT(Z) (Ganzzahliger (integer) Teil von Zahl 2): 
100 PRINT INT(54.67) Ganzzahliger Teil von 54.67 ist 54. 


© LEFT$(S$,L) (Linker Teilstring der Länge L in S$): 
100 PRINT LEFT$("BASIC",3) Die 3 linken Stellen sind "BAS". 


© LEN(S$) (Länge, d.h. Anzahl der Zeichen von S$): 
100 PRINT LENC"MWST") Länge des Strings "MWST" ist 4. 


© 10G(X) (Natürlicher Logarithmus): 
100 PRINT LOG(10) Nat. Logarithmus von 10 ist 2.30258509. 


e MID$(S$,S,L) (Mittlerer Teilstring von S$): 
100 PRINT MID$("BASIC",2,3) Ab 2. Stelle 3 St. lang: "ASI" 


e POS(0) (Spaltenposition des Cursors; 0 ganz links): 
100 PRINT POS(0O) Derzeitige Cursorposition ist z.B. 14. 


e RIGHT$(S$,L) (Rechter Teilstring der Länge L in S$): 
100 PRINT RIGHT$("MBASIC",2) Die 2 rechten Zeichen sind "IC". 


®@ RND(X) (Zufallszahl auswählen): 
100 PRINT RND(1) Zufallszahl zwischen O0 und 1 z.B. 0.56223. 


SGN(Z) (Vorzeichen von Zahl 2): 

100 ON SGN(E)+2 GOSUB 100,200,300 Verzweigung nach 100, 200 
bzw. 300 für E negativ (-1), null (0), positiv (1). 

e SIN(X) (Sinusfunktion) 


e SPC(L) (L Leerstellen ausgeben): 
100 PRINT "BASIC" ;SPC(10) ;"JA" 10 Blancs zwischen 2 Worten. 


e SOR(X) (Quadratwurzel von X): 
100 PRINT SQOR(49) Quadratwurzel von 49 ist 7. 


esT (Status z.B. der Floppy bereitstellen): 
100 IF ST<>O THEN PRINT "FEHLER" (z.B. ST=64 für Dateiende). 


e STR$(Z) (Zahl Z in String umwandeln): 
100 LET W$=STR$(45) zahl 45 als String "45" mit Länge 2. 


e TAB(X) (Tabulator-Funktion zur Ausgabe): 
100 PRINT TAB(8) ;'"A" "A" wird in Spalte 8 ausgegeben. 


e TAN(X) (Tangensfunktion) 
e TI (Interne Uhr lesen (TI jede 1/60stel Sek. um 1 erhöht)): 
100 PRINT TI Ausgabe z.B. 18000, wenn das Gerät 18000 mal 


1/60 Sekunden bzw. 5 Minuten angeschaltet war. 


eTI$ (Tageszeit als String "hhmmss" (h=Std., m=Min., s=Sek.) 
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eVAL(S$) (String S$ in numerischen Wert umwandeln): 


100 LET N=VAL("'347") "347" wird zu 347 (VAL("347DM") wird 0). 


2.3.2.3 Befehle für den Zugriff auf externe Einheiten 


Externe (also außerhalb des Hauptspeichers als Internspeicher 
befindliche) Einheiten werden durch Gerätenummern angesprochen 
wie: 


Gerätenumnmer: Externe Einheit: 
8 (auch 9-15) Diskette 
4 (auch 5) Drucker 
3 Bildschirm 
1 Kassette 
0 Tastatur 


Diese Nummern müssen in den Befehlen jeweils angegeben werden. 
Die folgenden Beispiele beziehen sich in erster Linie auf die 
Diskette, also auf die Gerätenumnmer 8. 


eCLOSE (Schließen einer logischen Datei): 


100 CLOSE 1 Datei mit der logischen Dateinummer 1 schließen. 
100 CLOSE Alle derzeit offenen Dateien schließen. 

eCop%y (Kopieren einer Datei auf einer Diskette): 
OPEN 1,8,15 Befehlskanal Öffnen und Pro- 
PRINT#1 ‚,"COPY : PROGNEU=PROGALT" gramm PROGALT zusätzlich unter 
CLOSE 1 dem Namen PROGNEU abspeichern. 


eGE T # (Ein einzelnes Zeichen von einer Datei lesen): 
100 OPEN 2,8,3,"DATEI,S,R" 


110 GET#2,E$: IFE$="" THEN 110 Zeichen nach E$ einlesen. 
120 CLOSE 2 
eINITIALIZE (Initialisierung bei Diskettenwechsel): 
OPEN 1,8,15 Befehlskanal öffnen, Disketten-BAM 
PRINT#1,"INITIALIZE" (Verzeichnis) in Floppy-Speicher lesen 
CLOSE 1 und Kanal schließen. 
eINPUTH (Daten von einer sequentiellen Datei lesen): 
100 OPEN 2,8,3,"DATEI,S,R" 
110 INPUT#2,B$,U Die nächsten beiden Daten (Trennungszei- 
120 CLOSE 2 chen trennnt sie) nach B$ sowie U einlesen. 
eLOAD (Laden eines Programms von Diskette in den RAM): 
LOAD "TEST4" ‚8 Hauptspeicher RAM loeschen und eine Kopie 
von Programm TEST4 von Diskette in den RAM bringen. 
eLonrAD "$" (Laden des Disketten-Inhaltsverzeichnisses): 
LOAD "'$",8 Inhaltsverzeichnis bzw. Direkctory von Diskette 
LIST in den RAM laden und auflisten (direkter Dialog). 
eNEW (Formatieren einer neuen Diskette): 
OPEN 1,8,15 Befehlskanal Öffnen, Diskette na- 
PRINT#1, "NEW: DISKNEU,04" mens DISKNEU mit Identifikation 04 


CLOSE 1 formatieren und Kanal schließen. 
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OPEN (Öffnen einer logischen Datei zur Vorbereitung des 
Datenverkehrs mit einem externen Gerät): 

100 OPEN 1,4 Drucker mit Gerätenummer 8 öffnen. 

100 OPEN 1,8,15 Öffnen des Befehls- und Fehlerkanals (Sekun- 
däradresse 15 eigens für diesen Kanal). 

100 OPEN 2,8,3,'"DATEI,S,R" Segq. Datei (S) namens DATEI auf 

100 OPEN 2,8,3,"DATEI,S,W" Diskette (8) zum Lesen (R),Schrei- 

100 OPEN 2,8,3,'"DATEI,S,A" ‘ben (W), Anhängen (A) eröffnen. 


PRINTH# (Schreiben auf eine sequentielle Datei): 

100 OPEN 2,8,3,"DATEI,S,W" 

110 PRINT#2,B$;",";U Als nächste Daten die Bezeichnung B$ 
120 CLOSE 2 > und den Umsatz U auf eine UmsatzDATEI speichern. 


RUN (Programm in den RAM laden und ausführen): 

RUN "'RECH" Derzeitigen Inhalt des RAM löschen, Programm RECH 
von Diskette laden und RECH dann ausführen. 

100 RUN "PROG6". Laden und ausführen von einem laufenden Pro- 
granm aus. Rufendes Programm gelöscht (Overlay). 


RENAME (Umbenennen einer Datei auf Diskette): 

OPEN 1,8,15 Befehlskanal Öffnen, Datei TEST 

PRINT#1 ,"RENAME:TEST31=TEST" in TEST31 umbenennen und Kanal 

CLOSE 1 schließen. 

SAVE (Speichern bzw. Retten eines Progamms auf Diskette): 

SAVE "RECH",8 Inhalt des RAM unter dem Programmnamen RECH 
auf Diskette speichern. 

SAVE "@:RECH" ‚8' Wie oben, aber bereits auf Diskette unter 
demselben Namen abgelegtes Programm überschreiben. 

SCRATCH (Löschen einer Datei auf Diskette): 

OPEN 1,8,15 Befehlskanal öffnen, Programm namens 

PRINT#1,"SCRATCH :TEST7" TEST7 löschen (zerstören) und Kanal 

CLOSE 1 schließen. 

VALIDATE (Prüfen der vorschriftsmäßigen Speicherung): 

OPEN 1,8,15 Befehlskanal öffnen, Löschen fehler- 

PRINT#1,"VALIDATE" hafter Dateien, Directory neu organi- 

CLOSE 1 sieren und Kanal schließen. 


VER TIFY (Vergleich eines Progamms im RAM und Diskette): 


VERIFY "RECHNEU" ,8 Kontrollvergleich des Programms RECHNEU, 


2.3.3 Operatoren für Rechnen, Vergleich und Logik 


Die BASIC-Anweisung 

100 PRINT 444*2+3000 /RET/ 
enthält hinter dem Anweisungswort PRINT einen Ausdruck mit den 
beiden Operatoren "*" (mal) und "+" (plus). In der 
Programmiersprache BASIC sind neben solchen "Rechenoperatoren' 
auch '"Vergleichsoperatoren' und "logische Operatoren' möglich. 
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Operatoren in BASIC und Rangfolge ihrer Ausführung 


Stehen in einem Ausdruck mehrere Operatoren, dann werden diese 
entsprechend der in der Übersicht wiedergegebenen Rangfolge 
ausgeführt: In Klammern gesetzte Operationen werden zuerst zur 
Ausführung gebracht (höchster Rang), die logische Verneinung 
dagegen zuletzt (niedrigster Rang). Im obigen Beispiel der An- 
weisung 100 PRINT 444*2+3000 wird zuerst mit "*" verdoppelt, 
um dann mit "+" zur Zahl 888 die Zahl 3000 zu addieren (Opera- 
tor "*" mit höherem Rang als Operator "+"). 

Auf die "Rechenoperatoren' sind wir bereits in Abschnitt 2.1.1 
eingegangen. 


Ein und derselbe Operator kann verschiedene Bedeutungen haben. 
So kann "+" addieren (3+4 ergibt 7) oder verknüpfen ("LE"+"NA" 
ergibt "LENA"). 

"-" kann vergleichen (20 IF X=3 GOTO 90: ist 'X gleich 3'?) 
oder einer Variablen einen Wert zuweisen (40 LET X=3: weise X 
den Wert 3 zu). 

Auf die Operatoren und deren Bedeutungen gehen wir ausführlich 
in Abschnitt 3 anhand von Programmbeispielen ein. 
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2.4 BASIC 4.0 als Zusatzsprache zur Dateiverarbeitung 


Das standardmäßig im ROM bereitgestellte BASIC meldet sich mit 
"Commodore 64 BASIC V2'"; es wird auch kurz als "CBM BASIC v2" 
bezeichnet. Es stimmt genau mit dem BASIC des VC 20 und auch 
mit dem BASIC 2.0 der '3000er-Serien' von Commodore überein. 
Nach dem BASIC 2.0 brachte Commodore das BASIC 4.0 heraus, 
das sich vom BASIC 2.0 in erster Linie in den Anweisungen zum 
Disketten-Zugriff (Relative Datei als Direktzugriff-Datei) un- 
terscheidet. 

Mit entsprechenden softwaremäßigen Erweiterungen kann auch auf 
dem Commodore 64 mit BASIC 4.0 programmiert werden. Dabei 
ändern sich die Disketten-Befehle wie folgt. 


2.4.1 Wichtige unterschiedliche Befehle von BASIC 4.0 und BASIC 2.0 





Diskettenzugriff in BASIC 2.0 und BASIC 4.0 


BASIC 2.0 ist aufwärtskompatibel zu BASIC 4.0 . Das bedeutet, 
daß ein "reines" BASIC-Programm, das auf einem Commodore 64 
in seiner ROM-Sprachversion 'CBM BASIC V2' geschrieben wurde, 
auch auf den größeren PCs von Commodore läuft,die inBASIC 4.0 

programmierbar sind. Rein beinhaltet, daß das jeweilige Pro- 
gramm ohne Tricks, die speziell auf die Rechnerstruktur des 
Commodore 64 abheben, arbeiten muß (PEEK, POKE, ...). 


98 2 Einstieg in die BASIC-Programmierung 
0000000000 Eiistieg IN AIE BASIL-FFOgrammıerung 


In den folgenden Abschnitten gehen wir näher auf das BASIC 4.0 
ein: 
- 3.8.2 Sequentielle Datei mit BASIC 4.0: 
Eine in BASIC 2.0 geschriebene Dateiverwaltung wird in die 
Sprache BASIC 4.0 übertragen. 
- 3.8.3 Direktzugriff-Datei mit BASIC 4.0: 
Demonstration der BASIC 4.0-Anweisungen DOPEN# und RECORD#, 
die später dann in BASIC 2.0 simuliert werden. 


2.4.2 Ausführung von C64-Programmen auf Commodore-Computern 
der Serien 2000/3000/4000/8000 


Wollen wir ein auf dem Commodore 64 geschriebenes Programm 
auf einem Commodore-Computer der Serien 2000, 3000, 4000 oder 
8000 (z.B. auf einem CBM 8032) laufen lassen, so geht das von 
den BASIC-Versionen her betrachtet in jedem Falle (Aufwärts- 
kompatibilität). 

Gleichwohl kann das C64-Programm nicht gestartet werden, da es 
an der 'falschen' RAM-Adresse gesucht wird: 


Commodore-Computer der Serien 2000/3000/4000 und 8000 suchen 
den Anfang eines BASIC-Programms bei Adresse 1025 im RAM. Beim 
Commodore 64 hingegen liegt diese Anfangsadresse bei 2049. La- 
den wir ein auf dem Commodore 64 geschriebenes Programm z.B. 
auf einem CBM 8032 „ so wird es durch LOAD wieder ab Adresse 
2049 abgelegt. Der LOAD-Befehl funktioniert also. 

Tippen wir RUN ein, dann sucht der BASIC-Interpreter den Pro- 
grammanfang an Adresse 1025. Da an diesem Speicherplatz nichts 
steht, kann das BASIC-Programm nicht zur Ausführung gebracht 
werden. 

Abhilfe schafft folgende Anweisungsfolge, die wir vor der 
Eingabe des LOAD-Befehls im direkten Dialog eintippen: 


POKE 40,1 /RET/ 
POKE 41,8 /RET/ 
POKE 8%256,0 /RET/ 
NEW /RET/ 


Durch diese POKE-Anweisungen setzen wir die Zeiger, die auf 
den Anfang eines BASIC-Programms zeigen, von ursprünglich 1025 
auf 2049 (der CBM-Computer wird also "angeschwindelt'). Der 
Anfangszeiger steht als 2-Byte-Adresse in den Adressen 40 und 
41 (Lowbyte 1 in 40 plus Highbyte 8%256=-2048 in 41 ergibt die 
Anfangsadresse 2049). Auf 2-Byte-Adressen gehen wir später in 
Abschnitt 3.5.5.1 genauer ein. 


Laden wir Programme in den Commodore 64, die auf Commodore- 
Computern der Serien 2/3/4/8000 geschrieben wurden, so treten 
diese Schwierigkeiten mit der Anfangsadresse nicht auf. 

Grund: Der Commodore 64 ist etwas intelligenter und lädt die 
BASIC-Programme automatisch an den Anfang seines Programmspei- 
chers, also in Adresse 2049. 

Gleichgültig, ob diese Programme zuvor durch den Befehl DSAVE 
bzw. SAVE das Adreßvermerk 1025 bzw. 2049 erhielten. 
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2.5 SIMON’s BASIC als Zusatzsprache für Grafik und Musik 


SIMON's BASIC wird von Commodore 
"BASIC-Erweiterung für Commodore 64" 
bezeichnet. 


SIMON's BASIC wird als Software auf Diskette (Disketten-BASIC) 
sowie als Firmware in einem Festwertspeicher bzw. Steckmodul 
(ROM-BASIC) geliefert. 
Nach dem Laden (LOAD) und Starten (RUN) des Disketten-BASIC 
bzw. nach dem Einschalten (Steckmodul) des ROM-BASIC meldet 
sich SIMON's BASIC mit: 

%*%% EXPANDED CBM V2 BASIC **% 

30719 BASIC BYTES FREE 

READY. 
Damit steht dem Benutzer zwar etwas weniger Speicherplatz als 
beim BASIC 2.0 zur Verfügung (38911 gegenüber 30719 Zeichen). 
Dies wird jedoch mehr als ausgeglichen durch die über 100 Be- 
fehle, die SIMON's BASIC zusätzlich bereitstellt. 


Die Spracherweiterungen von SIMON's BASIC betreffen insbeson- 
re folgende Anwendungsgebiete: 


- Hochauflösende Grafik (HIRES-Grafik für High Resolution Gra- 
fic) mit einer Auflösung von 320%200 Bildpunkten. 
In Abschnitt 3.9.3 gehen wir auf wichtige Grafik-Anweisungen 
ein. 


- Grafik mit Sprites als frei programmierbare Objekte, die bis 
24 Bildpunkte breit und 21 Punkte hoch sind. 
In Abschnitt 3.9.4 erklären das Speichern und Bewegen eines 
Sprite. 
In SIMON's BASIC werden Sprites als 'MOBs' (Moveable Object 
Blocks für Bewegbare Objekt-Blöcke) bezeichnet. 


- Strukturierendes Programmieren durch Anweisungen wie REPEAT- 
UNTIL für die Wiederholungsstruktur und IF-THEN-ELSE für die 
Auswahlstruktur. 

In Abschnitt 3.10 werden diese Anweisungen erläutert. 


- Musikverarbeitung als Programmieren des SID-Bausteins (Sound 
Interface Device). 
In Abschnitt 3.11 programmieren wir ein kleines Lied. 


- Programmierhilfen (Toolkit) wie RENUMBER (Programmzeilen neu 
numerieren) und TRACE (Testlauf mit Anzeige aller ausgeführ- 
ten Zeilennummern). 
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3.1 Grundlegende Programmstrukturen an Beispielen 


Wie in Abschnitt 1.3.3 dargestellt, lassen sich aus den vier 
grundlegenden Programmstrukturen 


- Folgestrukturen (linear, geradeaus) 

- Auswahlstrukturen (vorwärts verzweigend) 

- Wiederholungsstrukturen (rückwärts verzweigend, Schleife) 
- Unterprogrammstrukturen (unterteilend) 


alle nur denkbaren Programmabläufe konstruieren. Im vorliegen- 
den Abschnitt 3.1 wird zu jeder Programmstruktur ein in sich 
abgeschlossenes Demonstrationsbeispiel angegeben und erklärt. 
Programmierspache: BASIC auf dem Commodore 64 . 


3.1.1 Lineare Programme 

3.1.1.1 Codierung und Ausführungen zu einem Programm 

Jedes Programm hat einen Namen. Ein Programm namens VERBRAUCHI 
ermittelt den durchschnittlichen Benzinverbrauch für einen Pkw 


mit einem Tankinhalt von 60 Litern. 


Codierung zu VERBRAUCHI: Zwei Ausführungen zu VERBRAUCHI: 


10 LETT = 60 EINGABE: GEFAHRENE KM 
20 PRINT "EINGABE: GEFAHRENE KM" 27600 
30 INPUT K AUSGABE: LITER/100 KM 
40 LETD= 100 *T/K 10 
50 PRINT "AUSGABE: LITER/100 KM" 
60 PRINT D EINGABE: GEFAHRENE KM 
70 END ?542 
AUSGABE: LITER/100 KM 
11.0701107 


Tippt man den Befehl RUN ein, so wird das Programm ausgeführt: 
Der Computer gibt den Text "EINGABE: GEFAHRENE KM" aus . Der 
Benutzer gibt 600 ein, der Computer berechnet 10 L als Durch- 
schnittverbrauch, um dann den Text "AUSGABE: LITER/100 KM" und 
die Zahl 10 auszugeben. Bei der zweiten Ausführung entwickelt 
sich ein ähnlicher Mensch-Computer-Dialog, nur wird dabei von 
542 km ausgegangen. Beide Programmausführungen (auch Programm- 
lauf oder Dialogprotokoll genannt) werden dem Computer durch 
Anweisungen befohlen, die man sich durch Eintippen des Befehls 
LIST zeigen lassen kann. Das in der Programmiersprache BASIC 
codierte Programm VERBRAUCH1 umfaßt sieben Zeilen mit den Zei- 
lennummern 10-70 sowie vier Anweisungsarten LET, PRINT, INPUT 
und END. Das Programm wird Zeile für Zeile linear ausgeführt: 


- 10: Weise die Zahl 60 nach T (wie Tankfüllung) zu. 

- 20: Gib am Bildschirm den zwischen " '" stehenden Text aus. 

- 30: Warte auf eine Tastatureingabe und weise diese Eingabe 
dann der Variablen K (für Kilometer) zu. 

- 40: Rechne 100 mal T durch K aus und weise das Ergebnis dann 
der Variablen D (für Durchschnittsverbrauch) zu. 

- 50: Gib am Bildschirm den zwischen " " stehenden Text aus. 

- 60: Gib am Bildschirm den Inhalt der Variablen D aus. 

- 70: Beende die Ausführung des Programms VERBRAUHI. 
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Jede Programmzeile enthält hier die Zeilennummer (z.B. 30) mit 
Anweisungswort (z.B. INPUT) und Anweisungsargument (z.B. K). 
Die Codierung (auch Listing oder einfach Programm genannt) be- 
steht aus einer Folge von computerverständlich in BASIC formu- 
lierten Anweisungen. Dass einmal codiert e Pro- 
gramm kann dabei mehrmals ausgeführt wer- 
den, wobei sich die Ausführungen je nach Eingabewerten unter- 
scheiden können, die Codierung aber unverändert bleibt. 


Dies wird ermöglicht durch die Verwendung von Variablen (vgl. 
Abschnitt 1.3.4.2), hier durch die numerischen Variablen K und 
D. Während K und D ihren Inhalt (Wert) ändern, bleibt dieser 
bei T mit 60 Litern fest bzw. konstant: T ist eine Konstante. 
Daten können als Variable oder Konstante im 
Programm vorgesehen sein; hier sind beides numerische Daten. 


zu den Anweisungsarten: Die LET-Anweisung berechnet den rechts 


von "=" angebenenen Ausdruck und weist das Ergebnis der links 
von "=" stehenden Variablen zu. Bei LET (für (zu)lassen) darf 
links vom Zuweisungszeichen "=" immer nur eine vVariab- 


le stehen. Die PRINT-Anweisung dient der Ausgabe von Text (al- 
les, was zwischen Gänsefüßchen steht) wie in Zeilen 20 und 50 
oder der Ausgabe des Inhaltes einer Variablen wie in Zeile 60. 
Die INPUT-Anweisung dient der Tastatureingabe von Werten und 
deren Zuweisung in eine Variable wie etwa K in Zeile 30. Die 
END-Anweisung hat kein Argument und beendet die Ausführung. 


3.1.1.2 Anweisungsfolge Eingabe - Verarbeitung - Ausgabe 


Jedes Programm läuft in der Folge Eingabe-Verarbeitung-Ausgabe 
ab. Man spricht auch vom EVA-Prinzip (vgl. Abschnitt 1.2.2.1). 
Im folgenden Programm namens PREISSENKUNGI zeigt sich der 3er- 
Schritt in den Zeilen 20, 30 und 40. 


Codierung zu PREISSENKUNG]I: Ausführungen zu PREISSENKUNG]I: 
ALTER PREIS: 300 

10 REM ======PROGRAMM PREISSENKUNGI NEUER PREIS: 255 

20 INPUT "ALTER PREIS: ";P | 

30 LETP=P-P* 15 / 100 RUN 

40 PRINT "NEUER PREIS: ";P ALTER PREIS: 4925.65 

50 END NEUER PREIS: 4186.8025 


Die REM-Anweisung (engl. remark für Bemerkung) ermöglicht das 
Einfügen von Bemerkungen, die nur bei LIST erscheinen, nicht 
aber bei RUN. So erscheint hier der Programmname PREISSENKUNG!I 
bei den Ausführungen nicht. 
Die Zeile 20 hätte man auch umständlicher codieren können als 
20 PRINT "ALTER PREIS:"; 
21 INPUT P 
Da vor jedem INPUT ein PRINT stehen sollte -sonst weiß man ja 
nicht, was überhaupt einzutippen ist-, kann man mit Anweisung 
20 INPUT "ALTER PREIS: ";P 
die Eingabeanforderung mit der Eingabe zusammen in einer 
INPUT-Anweisung programmieren. 
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Die LET-Anweisung in Zeile 30 verdeutlicht den Unterschied des 
Zuweisungszeichens "=" (Zuweisung von links nach rechts) und 
des Gleichheitszeichens "=" in der Mathematik (links=rechts): 


30 LETP = P - P*15/100 
| I — 1) 200%15/100 ergibt 30 -200 in P 
| 2) 200-30 ergibt 170 -200 in P 
3) Weise 170 nach P zu -200 ersetzt 


Entsprechend bewirkt 180 LET Z=2+1 eine Werterhöhung von Z um 
1 und 230 LET X1=-X1/2 eine Halbierung von X1. 


Die PRINT-Anweisung in Zeile 40 zeigt, wie man sich konstanten 
Text und Variableninhalt nebeneinander ausgeben lassen kann: 
Das ; trennt ohne Leerzeichen (auch Blancs genannt). 

Auf die Gänsefüßchen kommt es an: PRINT "P" würde den Buchsta- 
ben P am Bildschirm zeigen, PRINT P den Wert der Variablen P. 


3.1.1.3 Übersichtliche Programmgliederung 


Man gliedert (siehe Abschnitt 1.3.4.3) jedes Anwenderprogramm 
-unabhängig von der jeweiligen Programmiersprache- übersicht- 
lich in drei Teile: 

Programmname, Vereinbarungsteil und Anweisungsteil. 

In BASIC ist diese explizite Dreiteilung nicht unbedingt er- 
forderlich. Insbesondere bei umfangreichen, langen Programmen 
sollte man die Dreiteilung mit REM-Anweisungen aber markieren. 
Das Programm PREISSENKUNG2 sieht diese Dreiteilung vor, wobei 
die Teile durch Leerzeilen und REM getrennt werden ( der Dop- 

pelpunkt ":" dient zur Darstellung einer Leerzeile).Im Verein- 
barungsteil ist S% als Ganzzahl-Konstante vereinbart (integer= 
ganzzahlig) und P als Dezimalzahl-Variable (real = Kommazahl). 

In BASIC ist es möglich, mehrere Anweisungen durch einen '":" 
getrennt in e i ne Zeile zu schreiben. Lange Zeilen sind 
unübersichtlich und schwer korrigierbar, das Zeichen ":"sollte 
weitgehend vermieden werden. In der letzten Zeile von Programm 
PREISSENKUNG2 werden mit dem ":'" die Anweisungen PRINT und 
END in einer Zeile programmiert. 


Codierung zu Programm PREISSENKUNG2: 


100 REM ======PROGRAMM PREISSENKUNG2 
110 : 
120 REM ======VEREINBARUNGSTEIL 


130 REM S%: INTEGER (PREISSENKUNG IN % KONSTANT 
140 LET S% = 15 
150 REM P: REAL (PREIS VARIABEL) 


160 : 

170 REM ======ANWEISUNGSTEIL 

171 PRINT "PREISSENKUNG UM 15% ERMITTELN." RUN 

180 INPUT "ALTER PREIS: ";P PREISSENKUNG UM 15% ERMITTELN. 
190 LETP=P-P* S% / 100 ALTER PREIS: 200 

200 PRINT "NEUER PREIS: ';P NEUER PREIS: 170 


210 PRINT "ENDE.": END ENDE. 
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PREISSENKUNG1 und PREISSENKUNG2 lösen beide dasselbe Problem. 
Die Codierungen unterscheiden sich wesentlich, die Ausführung- 
en hingegen kaum. 


3.1.1.4 Programmeingabe und Programmspeicherung 


Soll das Programm PREISSENKUNG2 erstmalig in den Computer ein- 
gegeben werden, geht man folgendermaßen vor: 


1. Befehl NEW tippen. Ein ggf. im Hauptspeicher RAM befind- 
liches Programm wird gelöscht. 

2. Programm Zeile für Zeile eintippen und am Ende jeder Zeile 
dabei die RETURN-Taste drücken. 

3. Befehl RUN tippen, um das Programm auszuführen und so zu 
testen. Falls fehlerhaft: Korrektur, weiter mit 2. 

4. Befehl LIST tippen und Codierung überprüfen. 

5. Befehl SAVE "PREISSENKUNG2",8 tippen: Das namenlos im RAM 
stehende Programm wird unter dem Namen PREISSENKUNG2 auf 
Diskette abgespeichert. 

Programm PREISSENKUNG2 befindet sich auf Diskette wie auch 
im RAM. Beide Programmkopien stimmen vollkommen überein. 

6. Zur Kontrolle: 

NEW tippen, RUN tippen: kein Programm ist mehr ausführbar. 
LOAD "PREISSENKUNG2",8 tippen: das Programm PREISSENKUNG2 
wird auf Diskette gesucht und eine Kopie in den RAM gela- 
Das Programm kann mit RUN nun ausgeführt werden. 

7. Befehle LOAD "$",8 und LIST tippen: die auf Diskette abge- 
legten Programme werden gezeigt, so auch PREISSENKUNG2. 
Achtung: LOAD "$",8 löscht das im RAM stehende Programm. 


Hinweis: Ist mit SAVE ein bereits auf Diskette unter demselben 
Namen vorhandenes Programm zu überschreiben, so ist der Befehl 
SAVE "®:PREISSENKUNG2",8 einzugeben (Klammeraffe "@" für das 
Überschreiben). 

Im RAM ist normalerweise nur e i n einziges Programm gespei- 
chert, auf der Diskette aber stets meh re r e Programme. 


3.1.1.5 Arbeitsschritte zur Programmentwicklung 


Je umfangreicher ein Programm, desto sinnvoller erscheint ein 
geplantes und schrittweises Vorgehen zur Programmentwicklung. 
In Abschnitt 1.3.7 nannten wir allgemein die Arbeitsschritte 
PROBLEMSTELLUNG, PROGRAMMENTWURF, PROGRAMMIERUNG, DOKUMENTA- 
TION und ANWENDUNG. "Allgemein' heißt, daß diese Schrittfolge 
auch zur Entwicklung komplexer Programm-Pakete geeignet ist. 
Für die in diesem Buch angeführten kleinen Demonstrationspro- 
gramme genügt eine vereinfachte Arbeitsschrittfolge: 1) Pro- 
lemstellung, 2) Problemanalyse, 3) Darstellungen des Algorith- 
mus, 4) Codierung in BASIC, 5) Anwendung/Ausführung und 6) Do- 
kumentation. 

Am Beispiel des ebenfalls linearen Programms KALKULATION! wol- 
len wir die Arbeitsschritte 1), 2), 4) und 5) darstellen. 


Problemstellung zu Programm KALKULATION]I: 

Es ist ein Dialogprogramm zu erstellen, das ausgehend vom Ein- 
standspreis den Nettoverkaufspreis und den Zuschlagsatz kalku- 
liert. 
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Problemanalyse zu Programm KALKULATIONI: 
In einer Variablen 1 is t e lassen sich die im Pro- 
gramm verwendeten Variablen so zusammenfassen: 


Ausgabedaten (Resultate): 
NET Nettoverkaufspreis in DM 
KALK Kalkulationszuschlag in % 
Eingabedaten (von Tastatur): 
EINST Einstandspreis in DM 


P1 Gemeinkostenzuschlag in % (von Hundert) 
P2 Gewinnzuschlag in % (von Hundert) 

P3 Skontosatz in % (im Hundert) 

P4: Rabattsatz in % (im Hundert) 


Verarbeitung (Formeln): 
GEMEIN Gemeinkosten in DM (GEMEIN=EINST*P1/100) 
SELBST Selbstkosten in DM (SELBST=EINST+GEMEIN) 
SPANNE Gewinnspanne in DM (SPANNE=SELBST*P2/100) 


BAR Barverkaufspreis in DM (BAR=SELBST+SPANNE) 
SKO Skontobetrag in DM (SKO=BAR*P3/(100-P3) 
ZIEL Zielverkaufspreis in DM (ZIEL=BAR+SKO) 
RAB Rabattbetrag in DM (RAB=ZIEL*P4/(100-P4)) 
NET Nettoverkaufspreis in DM (NET=ZIEL+RAB) 


KALK Kalkulationszuschlag (KALK=(NET-EINST)*100/EINST) 


Der folgende Schritt p lan zeigt eine grobe Darstel- 
lung des Lösungsablaufes vom Programm KALKULATIONI: 

Schritt 1: Vier Zuschlagsätze P1-P4 eintippen 

Schritt 2: Einstandspreis EINST eintippen 

Schritt 3: NET und KALK berechnen 

Schritt 4: NET und KALK als Resultat ausgeben 


Codierung zu Programm KALKULATIONI: 


100 REM ======PROGRAMM KALKULATIONI 

110 PRINT "WARENKALKULATION" 

120 PRINT "EINSTANDSPREIS -> NETTOVERKAUFSPREIS.": PRINT 
130 : | 

140 REM ======VEREINBARUNGSTEIL 

150 REM P1,P2,P3,P4: REAL (ZUSCHLAGSAETZE IN %) 

160 REM EINST, GEMEIN, SELBST, GEWINN, BAR, SKO, ZIEL, 
170 REM RAB, NET: REAL (EINZELBETRAEGE IN DM) 


180 REM KALK: REAL (KALKULATIONSZUSCHLAG IN %) 
190 : 

200 REM ======ANWEISUNGSTEIL 

210 REM *%**EINGABETEIL (<-TASTATUR) Hr ttkkksakskkkikiioksick 
220 INPUT "GEMEINKOSTEN IN % V.H.: "Pl 

230 INPUT "GEWINNZUSCHLAG IN % V.H.: ";P2 

240 INPUT "SKONTO IN % I.H.: ",p3 

250 INPUT "RABATT IN % I.H.: '"»P4 

260 INPUT "EINSTANDSPREIS IN DM: "EINST 


270 REM *»%* VERARBEITUNGSTEIL (WERTZUWEISUNGEN) Fr#r#** 
280 LET GEMEIN = EINST * P1 / 100 

290 LET SELBST = EINST + GEMEIN 

300 LET SPANNE = SELBST * P2 / 100 

310 LET BAR = SELBST + SPANNE 

320 LET SKO = BAR * P3 / (100 - P3) 

330 LET ZIEL = BAR + SKO 

340 LET RAB = ZIEL * P4 / (100 - P4) 
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350 LET NET = ZIEL + RAB 
360 LET KALK = (NET - EINST) * 100 / EINST 

370 REM ek AUSGABETEIL (->BILDSCHIRM) *aaaerakakaerirk 
380 PRINT : PRINT "VORWAERTSKALKULATION DURCHGEFUEHRT:" 
390 PRINT "NETTOVERKAUFSPREIS IN DM : ";NET 

400 PRINT "KALKULATIONSZUSCHLAG IN %: ";KALK 

410 END 


Anwendung bzw. Ausführung zu Programm KALKULATION]: 


WARENKALKULATION 


_ Ihre Aufgabe: Erweitern Sie 
EINSTANDSPREIS -> NETTOVERKAUFSPREIS. KALKULATIONI so, daß nicht 


GEMEINKOSTEN IN Z V.H.: 23 nur das Ergebnis, sondern „auch 
GEWINNZUSCHLAG IN ZzVH . 14 alle Zwischenschritte als Über- 
SKONTO IN 2 I.H.: —_ 2 sichtstabelle ausgegeben werden 
RABATT IN 2 L.H.: 25 (PRINT-Anweisungen einfügen). 
EINSTANDSPREIS IN DM: 100 


VORWAERTSKALKULATION DURCHGEFUEHRT: 
NETTOVERKAUFSPREIS IN DM : 190.77551 
KALKULATIONSZUSCHLAG IN %: 90.7755103 


3.1.2 Programme mit Verzweigungen 


Programmabläufe, die nach vorwärts verzweigen, werden als Aus- 
wahlstrukturen bezeichnet. Je nach der Anzahl der ausgewählten 
Fälle spricht man von der Zweiseitigen, Einseitigen oder Mehr- 
seitigen Auswahl(-struktur). Diese in Abschnitt 1.3.3.2 allge- 
mein beschriebenen Abläufe wollen wir in BASIC beispielhaft 
für den Commodore 64 an kleinen Programmen darstellen. 


3.1.2.1 Zweiseitige Auswahl 


Dem Programm SKONTOZWEISEITIG liegt folgende Problemstellung 
zugrunde: 

"Erwarte den Rechnungsbetrag R und die Tage T als Tastaturein- 
gabe und ermittle den Skontobetrag S. Dabei gelten folgende 
zahlungsbedingungen: Bei Zahlung nach 8 Tagen (T>8) 1.5% Skon- 
to, sonst (T<=8) jedoch 4% Skonto". 

Die Codierung, die Ausführung und der Programmablaufplan (PAP) 
zeigen uns die Zweiseitige Auswahl: einerseits 1.5% (Bedingung 
T>8 erfüllt, JA-Zweig mit THEN) und andererseits 4% (Beding- 
ung T>8 nicht erfüllt, NEIN-Zweig). 


Zwei Ausführungen zu SKONTOZWEISEITIG: 


SKONTO ALS ZWEISEITIGE AUSWAHL. SKONTO ALS ZWEISEITIGE AUSWAHL. 
RECHNUNGSBETRAG IN DM: 200 RECHNUNGSBETRAG IN DM: 200 
TAGE NACH ERHALT: 3 TAGE NACH ERHALT: 14 
8 DM SKONTO UND 192 DM ZAHLUNG. 3 DM SKONTO UND 197 DM ZAHLUNG. 


ENDE. ENDE. 
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Codierung zu SKONTOZWEISEITIG: PAP zu SKONTOZWEISEITIG: 


100 REM ======PROGRAMM SKONTOZWEISEITIG1 
110 PRINT "SKONTO ALS ZWEISEITIGE AUSWAHL." 
120 INPUT "RECHNUNGSBETRAG IN DM: ";R 

130 INPUT "TAGE NACH ERHALT: "T 

140 IF T > 8 THEN 190 

150 LETP=4 
160 LETTS=R*P/ 100: LETR=R-S 

170 PRINT S;" DM SKONTO UND ";R;" DM ZAHLUNG." 
180 PRINT "ENDE.": END 

190 LETP= 1.5 

200 GOTO 160 





zur bedingten Verzweigung wird dabei die 
IF-Anweisung in ihrer einfachsten Form verwendet: 


140 IF T>8 THEN 190 
Verzweigungsbedingung 
Sprungadresse 


Wenn (IF) T größer als 8 ist (T>), dann verzweige nach 
Zeile 190 . Wenn nicht, also wenn T kleiner oder gleich 8 
ist (T<=8), dann fahre wie sonst mit der Folgezeile 150 fort. 
Anstelle von THEN kann man auch THEN GOTO oder GOTO schreiben. 


zur unbedingten Verzweigung dient die 
GOTO-Anweisung. Kommt die Ausführung zu Zeile 200, so wird be- 
dingungslos nach Zeile 160 verzweigt (200 GOTO 160). 


Hier eine andere Codierung zu Programm SKONTOZWEISEITIG, die 
genauso abläuft wie die obige Codierungsform: 

140 IF T>8 THEN 152 

150 LET P=4 

151 GOTO 160 

152 LET P=1.5 

160 LET S=... 
Die END-Anweisung steht zwar als letzte Anweisung im Programm, 
aber das Zwischenspringen mit GOTO ist nicht gerade übersicht- 
lich. 


3.1.2.2 Einseitige Auswahl als Sonderfall 


Die Einseitige Auswahl 

"Wenn .., dann tue dies, sonst aber tue nichts" 
kann als Sonderfall der Zweiseitigen Auswahl 

"Wenn .„., dann tue dies, sonst aber tue das" 
aufgefaßt werden. 
Programm SKONTOEINSEITIG1 zeigt dies: Die Ausführungen stimmen 
mit denen von SKONTOZWEISEITIG überein, die Codierung hinge- 
gen zeigt eine Einseitige Auswahlstruktur . Dies wurde durch 
folgenden Trick erreicht: P wird in 140 auf 4% gesetzt und nur 
im Falle von T>8 um 2.5 auf 1.5% vermindert (190 LET P=P-2.5). 
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Codierung zu SKONTOEINSEITIG]: PAP zu SKONTOEINSEITIG]: 


100 REM ======PROGRAMM SKONTOEINSEITIG1 
110 PRINT '"SKONTO ALS EINSEITIGE AUSWAHL." 
120 INPUT "RECHNUNGSBETRAG IN DM: ";R 

130 INPUT "TAGE NACH ERHALT: ".T 

140 LETP=4 

150 IF T > 8 THEN 190 

160 LETS=R*P/ 100: LETR=R-S 

170 PRINT S;" DM SKONTO UND ";R;" DM ZAHLUNG." 
180 PRINT "ENDE.": END 

190 LETP=P- 2.5 

200 GOTO 160 





Ausführungen zu SKONTOEINSEITIGI: Struktogramnm : 


Eingabe R und T 
—_ 7 


= R*P/100 sowie 
Ausgabe von S und R 


SKONTO ALS EINSEITIGE AUSWAHL. 
RECHNUNGSBETRAG IN DM: 200 
TAGE NACH ERHALT: 3 

8 DM SKONTO UND 192 DM ZAHLUNG. 
ENDE. 









| 
ı 





SKONTO ALS EINSEITIGE AUSWAHL. 
RECHNUNGSBETRAG IN DM: 200 
TAGE NACH ERHALT: 14 

3 DM SKONTO UND 197 DM ZAHLUNG. 
ENDE. 





Die Programme SKONTOEINSEITIGI und SKONTOEINSEITIG2 weichen 
nur in der Codierung ab. Für die Verzweigungsanweisung IF-THEN 
wird in SKONTOEINSEITIG2 die Anweisung IF..THEN LET... verwen- 
det. LET wird aber nur dann ausgeführt, wenn die Verzweigungs- 
bedingung erfüllt ist. IF-Anweisungen wie IF..THEN PRINT.. und 
IF..THEN INPUT.. sind entsprechend möglich. Soll in Abhängig- 
ket der Verzeigungsbedingung aber eine Anweisungsfolge durch- 
laufen werden, so ist die einfache Form IF..THEN.. immer vor- 
zuziehen, da sie eine besser lesbare Codierung gewährleistet. 
Anmerkung: Für IF..THEN.. kann auch IF..THEN GOTO.. stehen. 


Codierung zu Programm SKONTOEINSEITIG2: 


100 REM ======PROGRAMM SKONTOEINSEITIG2 
110 PRINT '"SKONTO ALS EINSEITIGE AUSWAHL." 
120 INPUT "RECHNUNGSBETRAG IN DM: ";R 

130 INPUT "TAGE NACH ERHALT: T 

138 LETP=4 

140 IFT>8 THEN LETP=P - 2.5 

160 LETS=R*P/ 100: LETR=R-S 

170 PRINT S;'"' DM SKONTO UND ";R;'" DM ZAHLUNG." 
180 PRINT "ENDE.": END 
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3.1.2.3 Mehrseitige Auswahl als Sonderfall 


Bei der Mehrseitigen Auswahl werden mehrere Fälle unterschie- 
den: im Programm DREIFAELLEI sind es die drei Fälle 'gleich', 
'vor' und 'nach'. Der PAP und auch das Struktogramm zeigen uns 
die geschachtelte Anordnung von zwei 'Zweiseitigen Auswahlen'. 
Wie die Einseitige Auswahl kann also auch die Mehrseitige Aus- 


wahl als Sonderfall der Zweiseitigen Auswahl aufgefaßt werden. 
Struktogramm zu DREIFAELLEI: PAP zu DREIFAELLE]: 
Eingabe von W1$ und W2$ 


W1$=W2$ 


Ww1$<w2$ 


'nach' 'gleich' 


Programm beenden 





Codierung zu Programm DREIFAELLEI: 


100 REM ======PROGRAMM DREIFAELLEI 

110 PRINT "TEXTVERGLEICH: 2 WOERTER, 3 FAELLE." 

120 INPUT "ZWEI WOERTER: ";W1$,W2$ 

130 IF W1$ = W2$ THEN PRINT W1$;" IST GLEICH ";W2$: GOTO 160 
140 IF W1$ < W2$ THEN PRINT W1$;'' KOMMT VOR ";w2$: GOTO 160 
150 PRINT W1$;'" KOMMT NACH ";w2$ 

160 PRINT "ENDE.": END 


Zwei Ausführungen zu Programm DREIFAELLE]: 
TEXTVERGLEICH: 2 WOERTER, 3 FAELLE. TEXTVERGLEICH: 2 WOERTER, 3 FAELLE. 


ZWEI WOERTER: 12% „ HUNDERT ZWEI WOERTER: PREIS , DM-BETRAG 
12% KOMMT VOR HUNDERT PREIS KOMMT NACH DM-BETRAG 
ENDE. ENDE. 


In den IF-Anweisungen dieses Programms findet kein numerischer 
Vergleich statt, sondern ein Textvergleich : Die 
Verzweigungsbedingung W1$=W2$ (ist der Wert von Variable W1$ 
gleich dem von Variable W2$) vergleicht die derzeitigen Werte 
zweier Textvariablen. Textvariablen enden mit einem Dollar- 
zeichen $ (z.B. A$, B$, C$, ..., Al$, A2$, ...). Wie kann der 
Computer feststellen, ob mit dem Textvergleich W1$<W2$ in Zei- 
le 130 nun der Text "PREIS" kleiner ist (im Sinne von alphabe- 
tisch weiter vorne stehend) als der Text "DM-BETRAG"? Wie Zif- 
fern werden auch Buchstaben und Sonderzeichen intern im ASCII 
dargestellt (Abschnitt 1.2.3.1). Sie erhalten so je eine Code- 
nummer als Ordnungsnummer. Mit den ASCII-Codenummern 80 für P 
und 68 für D wird W1$<w2$ bzw. "PREIS"<"DM-BETRAG" bzw. 80<68 
vom Computer als 'unwahr' erkannt; der Textvergleich führt so- 
mit nicht zur Programmverzweigung. 

Text ist all! das, 'was zwischen Gänsefüßchen steht' .„. Andere 
Bezeichnungen sind S t rin g ,„ Zeichenkette, Zeichendaten. 
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Beim Textvergleich kann wie beim numerischen Vergleich mit den 
Vergleichs-Operatoren =, <> (ungleich), >,< ,>= (größer oder 
gleich) und <= gearbeitet werden. 


Beim Commodore 64 kann ein String maximal 255 Zeichen lang 
sein. 


In den Zeilen 130, 140 und 160 von Programm DREIFAELLEI sind 
mehrere Anweisungen in e ine r Zeile angeführt (":" dient 
als Trennungszeichen). Mit dem ":" sollte sparsam umgegangen 
werden, weil sich lange Programmzeilen schlecht lesen und kor- 
rigieren lassen. 


3.1.2.4 Fallabfrage 


Die Schachtelung von mehr als zwei Auswahlstrukturen wird all- 
zuleicht unübersichtlich. Zur Vereinfachung der Mehrseitigen 
Auswahl bietet BASIC deshalb die Fallabfrayge mit 
der Anweisung ON..GOTO an. Das Programm MWST1I zeigt, daß über 
die eine Anweisung 

240 ON WAHL GOTO 250,260,270 
d re i Verzweigungen ausgeführt werden: Für WAHL=1 wird nach 
Zeile 250 verzweigt, für WAHL=2 nach Zeile 260 und für WAHL=3 
nach Zeile 270. 
Da die Anweisung ON..GOTO in WAHL ganzzahlige Werte erwartet, 
müssen entsprechende Eingabefehler zuvor in den Zeilen 220 und 
230 abgewiesen werden. INT(WAHL) liefert den ganzzahligen Teil 
von WAHL (INT(3.45) ergibt 3; INT(2.9) ergibt 2). 


Struktogramm zu MWST]1: Zwei Ausführungen zu MWSTI: 


Eingabe der Auswahl WAHL BRUTTO EINSCHL. MEHRWERTSTEUER. 
NETTOBETRAG TIPPEN: 1500 

OHNE MWST 1 

Fallabfrage VOLLE MWST 2 

HALBE MWST 3 

WAHL 1 - 3 TIPPEN: 2 
BRUTTOBETRAG: 1710 DM. 


RUN 
ohne voll BRUTTO EINSCHL. MEHRWERTSTEUER. 
NETTOBETRAG TIPPEN: 1500 
VOLLE MWST 2 
HALBE MWST 3 
Codierung zu Programm MWSTI1: WAHL 1 - 3 TIPPEN: 3 
BRUTTOBETRAG: 1605 DM. 





100 REM ======PROGRAMM MWST1 

110 PRINT "BRUTTO EINSCHL. MEHRWERTSTEUER." 
120 REM ======VEREINBARUNGSTEIL 

130 REM NET, MWST, BRUT: REAL 

140 REM WAHL: INTEGER 

150 : 
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160 REM ======ANWEISUNGSTEIL 

170 INPUT '"NETTOBETRAG TIPPEN: '";NET 

180 PRINT "OHNE MWST 1" 

190 PRINT "VOLLE MWST 2" 

200 PRINT "HALBE MWST 3" 

210 INPUT "WAHL 1 - 3 TIPPEN: ";WAHL 

220 IF WAHL < 1 OR WAHL > 3 THEN PRINT "INTERVALL.": GOTO 180 
230 IF WAHL < > INT (WAHL) THEN PRINT "GANZZAHLIG.": GOTO 180 
240 ON WAHL GOTO 250,260,270 


250 LET MWST = 1: GOTO 280 
260 LET MWST = 1.14: GOTO 280 
270 LET MWST = 1.07 

280 LET BRUT = NET * MWST 


290 LET BRUT = INT (BRUT * 100 + 0.5) / 100 
300 PRINT "BRUTTOBETRAG: ";BRUT;" DM." 
310 END 


3.1.3 Programme mit Schleifen 


Programme mit Schleifen enthalten Wiederholungsstrukturen, die 
nach der allgemeinen Darstellung in Abschnitt 1.3.3.3 jetzt in 
Commodore-BASIC an Beispielen veranschaulicht werden sollen. 


3.1.3.1 Abweisende Schleife 


Programm KAPITAL! ermittelt für ein Kapital K bei einem Zins- 
satz P das verzinste Kapital zum Ende des 1., 2., 3. .. Jahres 
und endet, sobald sich das Anfangskapital verdoppelt hat. Jede 
Schleife besteht aus einem Vorbereitungsteil (einmal durchlau- 
fen: Zeilen 180-200) und aus einem Wiederholungsteil (mehrmals 
durchlaufen: Zeilen 220-250); im Ausführungsbeispiel wird die- 
ser 9mal durchlaufen. 

Die Schleife in Programm KAPITAL! heißt abweisend, da 
die Schleifenabfrage 220 IF K<=KE THEN 270 am Anfang des 
Wwiederholungsteils steht und damit eine versuchte Wiederholung 
abweisen kann. Andere Bezeichnungen für diesen Schleifentyp: 
WHILE-DO-Schleife, So-lange-tue-Schleife, Schleife mit vorhe- 
riger Abfrage. 


100 REM =======KAPITAL1 PAP zu KAPITAL]: 
110 PRINT "KAPITALIEN BIS ZUR VERDOPPLUNG." 
120 REM ======VEREINBARUNGSTEIL 

130 REM K: REAL (KAPITAL IN DM) 

140 REM KE: REAL (ENDKAPITAL IN DM) 

150 REM P: REAL (ZINSSATZ IN %) 


160 : 

170 REM ======ANWEISUNGSTEIL 

180 INPUT "EINGESETZTES KAPITAL: ";K 
190 INPUT "JAHRESZINSSATZ: ",p 


200 LETKE=2*K 

210 REM ***BEGINN DER ABWEISENDEN SCHLEIFE**** tx x%% 
220 IFK> = KE THEN 270 

230 LETK = K +K * P / 100 

240 PRINT" ";K 

250 GOTO 220 

260 REM ***SCHLEIFENENDE*Kkkasklaktakkkkkiekekakkk 


270 PRINT "ENDE NACH VERDOPPLUNG.": END 
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Struktogramm zu KAPITAL]: Ausführung zu KAPITAL]: 






KAPITALIEN BIS ZUR VERDOPPLUNG, 
EINGESETZTES KAPITAL: 50000 


Schleife vorbereiten: 
K, P und KE festlegen 











JAHRESZINSSATZ: 9 
Solange K<KE ist, wiederhole 54500 
59405 
verzinstes Kapital K aus: 64751.45 

= K+ (K* P / 100) 70579..0805 

76931.1978 

91401.9561 

108594 .664 





ENDE NACH VERDOPPLUNG. 
3.1.3.2 Nicht-abweisende Schleife 


Die Ausführungen der Programme KAPITAL2 und KAPITALI stimmen 
überein, nicht aber ihre Codierungen: Programm KAPITAL2 hat 
eine nicht - abwe isende Schleife, da bei der 
Codierung die Schleifenabfrage am Ende des Wiederholungsteils 
in Zeile 240 steht. 

Andere Bezeichnungen für die nicht-abweisende Schleife sind: 
REPEAT-UNTIL-Schleife, Wiederhole-bis-Schleife sowie Schleife 
mit nachheriger Abfrage. 


Struktogramm zu KAPITAL2: PAP zu KAPITAL2: 


Anfangswerte K, P und KE 
K = K+(K*P/ 100) 


wiederhole bis K>=KE ist 


Programmende 


Codierung zu Programm KAPITAL2: 











100 REM ======KAPITAL2 
110 PRINT "KAPITALIEN BIS ZUR VERDOPPLUNG." 
120 REM ======VEREINBARUNGSTEIL 


130 REM K: REAL (KAPITAL IN DM) 
140 REM KE: REAL (ENDKAPITAL IN DM) 
150 REM P: REAL (ZINSSATZ IN %) 


160 : 

170 REM ======ANWEISUNGSTEIL 

180 INPUT "EINGESETZTES KAPITAL: ";K 
190 INPUT "JAHRESZINSSATZ: ",p 


200 LETKE=2*K 

210 REM *%*BEGINN DER NICHT-ABWEISENDEN SCHLEIFE*** 
220 LETK=K+K*P / 100 

230 PRINT" "x 

240 IF K < KE THEN 220 

250 REM **&*SCHLEIFENENDEFFRAKHHRRRRKRRRIR ERICH 


260 PRINT "ENDE NACH VERDOPPLUNG.": END 
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3.1.3.3 Schleife mit Abfrage in der Mitte 


Am Spielprogramm ZUFALL1I wollen wir den Schleifentyp "Abfrage 
in der Mitte des Wiederholungsteils' zeigen: Die Schleifenab- 
frage 280 IF Z=D GOTO 330 befindet sich inmitten des Wieder- 
holungsteils (Zeile 260 bis Zeile 310). Aus dem Struktogramm 
sehen wir deutlich, daß innerhalb der Schleife noch eine Zwei- 
seitige Auswahlstruktur eingeschachtelt ist: Wenn Z2>D, dann zu 
groß, sonst zu klein. Dieses Programm ZUFALLI ist also bereits 
recht komplex mit drei Programmstrukturen: Folgestruktur (200- 
240), dann Wiederholungsstruktur (260-310) mit eingeschachtel- 
ter Auswahlstruktur (290-310). 


zu den zwi Funktionen RND() und INT in Zeile 230: 

RND() (von Random=Zufall) erzeugt eine Zufallszahl zwischen 0 

und 1. Dabei kommt es auf den in Klammern gesetzten Wert an: 

- RND(negative Zahl) erzeugt eine Startzahl für eine Zufalls- 
folge. 

- RND(-TI) setzt die Startzahl in Abhängigkeit des internen 
Zeittaktes TI (vgl. Abschnitt 2.3). 

- RND(positive Zahl) liest eine Zahl aus einer mit RND(negati- 
ve Zahl) gewählten Zufallsfolge. Beispiele: RND(1), RND(A). 

Die zusätzliche Anweisung 195 LET D=RND(-TI) würde sicher- 

stellen, daß bei jedem Programmlauf von ZUFALLI eine "andere' 

zufallszahl gewählt wird. 


Die Funktion INT (von Integer=ganzzahlig) schneidet eventuell 

vorhandene Kommastellen ab. Die hier im Ausführungsbeispiel zu 

Programm ZUFALL! vom Computer erzeugte Zahl 108 kann in Zeile 
230 LET D = INT(A*RND(A)+N) 

zum Beispiel wie folgt nach D zugewiesen worden sein: RND(A) 

ergibt 0.88249; A bzw. 10 mal 0.88249 ergibt 8.8249;N bzw. 100 

plus 8.8249 ergibt 108.8249; INT(108.8249) ergibt 108. 


100 REM ======PROGRAMM ZUFALL] 

110 PRINT "RATEN EINER ZAHL ALS SPIELPROGRAMM." 
120 : 

130 REM ======VEREINBARUNGSTEIL 


140 REM Z: REAL (JEWEILIGE BENUTZEREINGABE) 
150 REM D: INTEGER (ZUFALLSZAHL DES COMPUTERS) 
160 REM A,N: INTEGER (GRENZEN FUER ZUFALLSAUSWAHL) 
170 REM V: INTEGER (VERSUCHSZAEHLER) 

180 : 

190 REM ======ANWEISUNGSTEIL 

200 PRINT "EINE ZAHL WIRD ZUFAELLIG AUS DEN A" 

210 PRINT "AUF N FOLGENDEN ZAHLEN ERZEUGT." 

220 INPUT "BITTE A, N EINTIPPEN: ";A,N 

230 LETD= INT (A * RND (A) + N): LETV=0O 

240 PRINT : PRINT "SPIELBEGINN COMPUTER - BENUTZER: " 
250 REM *%**BEGINN DER RATESCHLEIFERFRKKKKKSCKKK CK 
260 INPUT "IHRE ZAHL BITTE: ";Z 

270 LETV=V +1 

280 IF Z = D GOTO 330: REM SCHLEIFENABFRAGE 

290 IF Z > D GOTO 310 

300 PRINT "... ZU KLEIN.": GOTO 260 

310 PRINT "... ZU GROSS.": GOTO 260 

320 REM ENDE DER SCHLEIFE?**3k3k>k>kakakakakakakakakakakakakakakacck 
330 PRINT "TREFFER ";D;" NACH ";V;'" VERSUCHEN." 

340 PRINT "ENDE DES SPIELS." 
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Struktogramm zu ZUFALLI: Ausführung zu ZUFALLI: 


Anfangswerte A,N,D und V 
zahl Z eintippen 


Versuche V = V+1 
wenn D=Z Schleifenende 


Treffer D und Versuche V 





RATEN EINER ZAHL ALS SPIELPROGRAMM. 
EINE ZAHL WIRD ZUFAELLIG AUS DEN A 
AUF N FOLGENDEN ZAHLEN ERZEUGT. 
BITTE A, N EINTIPPEN: 10,100 







SPIELBEGINN COMPUTER -— BENUTZER: 
IHRE ZAHL BITTE: 107 

... ZU KLEIN. 

IHRE ZAHL BITTE: 109 

TREFFER 109 NACH 2 VERSUCHEN. 
ENDE DES SPIELS. 










3.1.3.4 zählerschleife 


Läßt man ein Testprogramm auf verschiedenen Computern laufen, 
um über den Vergleich der Ergebnisse deren Leistungen zu beur- 
teilen, spricht man von einem Benchmark-Test. 

Ein einfacher Test besteht darin, 2000 mal 10 durch 3 zu tei- 
len, um über die hierfür benötigte Zeit dann auf die Verarbei- 
tungsgeschwindigkeit des Computers bzw. der CPU zu schließen. 
Das Programm BENCHMARK-TESTI enthält dieses Testverfahren. 
Der Programmlauf auf einem Commodore 64 benötigte ungefähr 
17 Sekunden. 


In der Zeile 130 von Programm BENCHMARK-TESTI ist eine Zäh- 
lerschleife, die sich genau 2000 mal wiederholt: die Variable 
2 durchläuft die Werte 1,2,3,.-..,2000 und heißt deswegen 
auch Laufvariab 1 e. Da 2 dabei jeweils um 1 hochge- 
zählt wird, nennt man sie Zählervariable und kurz Zähler. 
zur Kontrolle der zZählerschlei f e stellt Commo- 
dore-BASIC die Anweisungen FOR - NEXT zur Verfügung (häufig 
FOR-Schleife genannt). 

Statt in einer Zeile kann man die Zählerschleife von Programm 
BENCHMARK-TESTI auch wie folgt in drei Zeilen schreiben: 


130 FOR Z=1 TO 2000 -Für Z, das von 1 bis 2000 laufen soll 
131 LET T=10/3 -Bei jedem Durchlauf 10/3 nach T bringen 
132 NEXT Z -Z um 1 erhöhen und ggf. nach 130 gehen 


Da die Überprüfung der Schleife am Ende in der NEXT-Anweisung 
stattfindet, wird eine Schleife mit FOR X=5 TO 5 ... NEXTX 
ein ma 1 durchlaufen. 

Der PAP zu PBENCHMARK-TESTI zeigt die Sinnbilder für der Zäh- 
lerschleife: 

Zwei 'abgeschrägte' Rechtecke für den Schleifenanfang (FOR) 
und für das Schleifenende (NEXT). 
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Codierung zu BENCHMARK-TESTI: PAP zu BENCHMARK-TEST]I: 


100 REM ======BENCHMARK-TESTI 

110 PRINT "TEST ZUR VERARBEITUNGSGESCHWINDIGKEIT." 
120 PRINT T;" -> TESTBEGINN (BITTE WARTEN)" 

130 FOR Z = 1 TO 2000: LET T = 10 / 3: NEXT Z 

140 PRINT T;" -> TESTENDE" 

150 END 


Ausführung zu BENCHMARK-TESTI: 


TEST ZUR VERARBEITUNGSGESCHWINDIGKEIT. 
O0 -> TESTBEGINN (BITTE WARTEN) 
3.33333333 -> TESTENDE 


Struktogramm zu BENCHMARK-TEST]I: 


Ausgabe T 


Für Z von 1 bis 2000 wiederhole 









Zuweisung T = 10/3 
Ausgabe T 


Beispiele für gültige FOR-Anweisungen (Werte der Laufvariablen 
in Klammern): FOR I=100 TO 102 (100,101,102), FOR S1=3 TO EWER 
(3,4 bei EWER=4), FOR D=0 TO 6 STEP 2 (0,2,4,6), FOR A=9 TO 13 
STEP 3 (9,12), FOR I=8 TO 6 STEP -1 (8,7,6), FOR A=1 TO 1 (1). 
Mit STEP kann man dabei für die Laufvariable eine von 1 abwei- 
chende Schrittweite angeben. Ist STEP negativ, so muß der An- 
gangswert naturlich größer sein als der Endwert. 





3.1.3.5 Unechte Zählerschleife 


Eine unech t e Zählerschleife liegt vor, wenn mit den 
Anweisungen FOR-NEXT überhaupt nicht gezählt werden soll, d.h. 
wenn diese beiden so bequem verwendbaren Anweisungen 'nur' zum 
Zwecke der Schleifensteuerung programmiert werden. Das folgen- 
de Programm FAHRTENBUCHI zeigt dies anhand einer Kfz-Benzin- 
abrechnung. 

In der Zählerschleife (Zeilen 260 - 370) wird in der Anweisung 
260 FOR Z = 1 TO 999 mit 999 ein normalerweise nicht erreich- 
barer Endwert angegeben, weil der eigentliche Schleifenausgang 
in Zeile 290 vorgesehen ist: Bei Eingabe von Null (K1=0?) wird 
die Laufvariable auf 999 gesetzt (LET 2=999) und nach 370 zur 
NEXT-Anweisung verzweigt. Ebenso könnte die Schleife durch ei- 
ne Verzweigung 290 IF K1=0 THEN 380 direkt verlassen; diese 
Möglichkeit widerspricht jedoch dem Prinzip der strukturierten 
Programmierung, für jede Programmstruktur je einen Ein- 
gang und Ausgang vorzusehen (vgl. Abschnitt 1.3.7.4). 
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Unechte Zählerschleife auf zwei Arten programmiert 
Ausführung zu Programm FAHRTENBUCHI1: PAP zu FAHRTENBUCHI: 


KFZ-BENZINVERBRAUCHSWERTE ERMITTELN 
AUS EINTRAGUNGEN IM FAHRTENBUCH. 


ANFANGSKILOMETERSTAND (TANK=VOLL): 60000 
1. TANKEN: KM-STAND, LITER, DM (O=ENDE) 
60100,10,14 

VERBRAUCH: 10 LITER/100 KM 
BENZINPREIS: 1.4 DM/LITER 


2. TANKEN: KM-STAND, LITER, DM (O=ENDE) 
60260, 20,29 

VERBRAUCH: 12.5 LITER/100 KM 
BENZINPREIS: 1.45 DM/LITER 





3. TANKEN: KM-STAND, LITER, DM (O=ENDE) 
0,0,0 


KILOMETER GESAMT: 260 KM 

AUSGABEN GESAMT: 43 DM MI 
VERBRAUCH MITTEL: 11.5384615 LITER/100 KM 

BENZINPREIS MITTEL: 1.43333333 DM/LITER en) 


Codierung zu FAHRTENBUCHI mit einer Schleife in 260-370: 


100 REM ======PROGRAMM FAHRTENBUCHI 

110 PRINT "KFZ-BENZINVERBRAUCHSWERTE ERMITTELN" 
120 PRINT "AUS EINTRAGUNGEN IM FAHRTENBUCH.": PRINT 
130 : 

140 REM ======VEREINBARUNGSTEIL 

150 REM Kl: REAL (KM-STAND AUS FAHRTENBUCH) 

160 REM Lil: REAL (LITERVERBRAUCH AUS F.) 

170 REM Dil: REAL (DM-BETRAG FUER TANKEN AUS F.) 
180 REM Vl: REAL (VERBRAUCH IN LITER/100 KM) 

190 REM Bl: REAL (BENZINPREIS IN DM/LITER) 

200 REM K,L,D,V,B: REAL (ENTSPR. GESAMTWERTE) 

210 REM 2: INTEGER (LAUFVARIABLE) 

220 : 

230 REM ======ANWEISUNGSTEIL 

240 INPUT "ANFANGSKILOMETERSTAND (TANK=VOLL): ";KO 
250 LETK = O0:L = 0:D= 0 


3.1 Grundlegende Programmstrukturen an Beispielen 117 


260 FOR Z = 1 TO 999 

270 PRINT Z;". TANKEN: KM-STAND, LITER, DM (O=ENDE)" 
280 INPUT " "sK1,L1,Dl 

290 IF Kl = O THEN LET Z = 999: GOTO 370 


300 LETK1 =K1-KO:K=K+Kl:L=L+L1l:D=D+Dl 
310 LETVI1 = 100 *L1/ Kl 
320 PRINT "VERBRAUCH: ";V1;" LITER/100 KM" 


330 LETBL=DI /Ll 
340 PRINT "BENZINPREIS: ";B1;'' DM/LITER" 
350 LET KO = KO + Kl: PRINT 


360 NEXT Z 

370 LETV= 100 *L/K: LETTB=D/L: PRINT 

380 PRINT "KILOMETER GESAMT: ";K;" KM" 

390 PRINT "AUSGABEN GESAMT: "zD;'" DM" 

400 PRINT "VERBRAUCH MITTEL: ";V;" LITER/100 KM" 
410 PRINT "BENZINPREIS MITTEL: ";B;'" DM/LITER" 

420 END 


Offene und geschlossene Schleife: 

Zu Beginn jeder Ausführung von Programm FAHRTENBUCHI ist voll- 
kommen offen, wie oft die Schleife durchlaufen wird. Man nennt 
diese Schleife deshalb auch eine o f fe ne Schleife. Dem- 
gegenüber wurde BENCHMARK-TEXTI als geschlossene 
Schleife jeweils immer 2000 mal durchlaufen. Die Anzahl der 
Schleifendurchläufe ist dabei konstant. 


3.1.3.6 Schachtelung von Zählerschleifen 


Mehrere Programmstrukturen können entweder hintereinander oder 
geschachtelt in e i ne m Programm angeordnet sein (vgl. Ab- 
schitt 1.3.3.5). Bei der Schachtelung von Zählerschleifen ist 
zu beachten, daß die zuerst begonnene äußere Schleife zuletzt 
beendet wird, daß die innere Schleife somit vollständig einge- 
schachtelt ist. Im Beispiel mit X-Schleife außen und Y-Schlei- 
fe innen wird in 400 das Wort TEST 12 mal (3%4=-12) ausgegeben. 


-300 FOR X=1 TO 3 
Ir310 FOR Y=1 TO 4 


FOR X=1 TO 3 

FOR Y=1 TO 4 

400 PRINT "TEST" PRINT "TEST" 

NER läuft nicht 
590 NEXT Y 





NEXT X 
600 NEÄT X NEXT Y 
vollständige Schachtelung falsch: teilweise Schachtelung 


Schachtelung mit innerer Y-Schleife und äußerer X-Schleife 


Im Programm RATENSPARTABELLE sind ebenfalls 2 Zählerschleifen 
geschachtelt angeordnet: Die innere Schleife mit der Laufvari- 
ablen I für die Jahre (im Ausführungsbeispiel I=1,2,3,4) sowie 
die äußere Schleife mit J für die Anzahl der jährl. Zahlungen 
(im Beispiel J=1,2). Die Beispieltabelle weist damit 8 Druck- 
zeilen auf, da die PRINT-Anweisung in Zeile 340 genau 8 mal 
(4*%2=8) durchlaufen wird. 
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Codierung zu RATENSPARTABELLE (Schleifen in Zeilen 310-360): 


100 REM ======PROGRAMM RATENSPARTABELLEI 
110 PRINT "GUTHABENENTWICKLUNG BEIM RATENSPAREN" 
120 PRINT "ALS UEBERSICHTSTABELLE." 


130 : 

140 REM ======VEREINBARUNGSTEIL 

150 REM S: REAL (SPARRATE GLEICHBLEIBEND) 

160 REM Z: ° INTEGER (ANZAHL DER ZAHLUNGEN PRO JAHR) 

170 REM V: INTEGER (VERTRAGSLAUFZEIT DES RATENSPARENS) 
180 REM P: REAL (JAHRESZINSSATZ) 

190 REM F: REAL (ZINSFAKTOR AUS ZINSFORMEL) 

200 REM K: REAL (KAPITAL ALS NEUES ENDGUTHABEN) 

210 REM 1: INTEGER (LAUFVARIABLE AEUSSERE JAHRESSCHLEIFE) 
220 REM J: INTEGER (LAUFVARIABLE INNERE MONATSSCHLEIFE) 
230 : 

240 REM ======ANWEISUNGSTEIL 

250 INPUT "SPARRATE, ZAHLUNGEN/JAHR: "5,2 

260 INPUT "VERTRAGSLAUFZEIT (JAHRE): "V 

270 INPUT "ZINSSATZ (%/JAHR): ".p 


2860 LETK= 0: LETF=1+P/2Z/ 100 

290 PRINT : PRINT "JAHR MONAT GUTHABEN" 

300 REM BEGINN DER SCHLEIFENSCHACHTELUNGFF** 
310 FOR I = 1 TO V: REM BEGINN SCHLEIFE "AUSSEN' 
320 : FOR J = 1 TO Z: REM BEGINN SCHLEIFE INNEN 
330 :: LETK= ((K+S)*F 

340 :: PRINT TAB( 2);I; TAB( 7);J; TAB( 13); INT (K * 100 + 0.5) \ 100 
350 : NEXT J: REM ENDE SCHLEIFE INNEN 

360 NEXT I: REM ENDE SCHLEIFE AUSSEN 

370 REM ?®%&*ENDE DER SCHLEIFENSCHACHTELUNGFFF#** 
380 PRINT "ENDE.": END 


Struktogramm zu RATENSPARTABELLE: Ausführung zum Programm: 
Anfangswerte S,2,V,P,K,F 
Überschriftzeile ausgeben 






GUTHABENENTWICKLUNG BEIM RATENSPAREN 
ALS UEBERSICHTSTABELLE. 

SPARRATE, ZAHLUNGEN/JAHR: 200,2 
VERTRAGSLAUFZEIT (JAHRE): 4 
ZINSSATZ (%/JAHR): 12 





JAHR MONAT GUTHABEN 







für J von 1 bis 2 1 1 212 
1 2 436.72 
2 1 674.92 
Guthaben K ermitteln 2 2 927.42 
und Zeile ausgeben 3 1 1195.06 
3 2 1478.77 
4 1 1779.49 
4 2 2098.26 
ENDE. 
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3.1.3.7 Warteschleife bei Zeitverzögerung und GET 


Die Programmschleife 

100 FOR ZEIT=1 TO 1000 

110 NEXT ZEIT 
wird 1000 mal durchlaufen, was seine Zeit braucht. Deshalb 
sieht man diese Schleife oft als Warteschleife zur Zeitverzö- 
gerung vor. 
Man schreibt die Warteschleife auch einzeilig in der Form 

100 FOR ZEIT=1 TO 1000 : NEXT ZEIT . 


Einem ganz anderen Zweck dient die folgende Warteschleife: 

300 PRINT "ERKLAERUNG (JA/NEIN)?" 

310 GET E$ 

320 IF E$="J" THEN 350 

330 IF E$="N" THEN 500 

340 GOTO 310 

350 PRINT "ERKLAERUNG: ...." 
Die GET-Anweisung erwartet e i n Zeichen als Tastatureinga- 
be, ohne daß die S/RET/-Taste gedrückt werden muß. Sobald ein 
Zeichen eingetippt wurde, wird es mittels 310 GET E$ nach E$ 
zugewiesen. GET verlangt stets eine Warteschleife (hier: Zeile 
310,320,330,340,310, ...), da immer wieder die Tastatur nach 
einer Eingabe abgefragt wird. 
Die Warteschleife können wir auch in einer Zeile schreiben: 

310 GET E$: IF E$="" THEN 310 

320 IF E$="J" THEN 350 

330 GOTO 500 
Die Ablauflogik ist dabei jedoch weniger streng, da für alle 
Eingaben außer "J" keine Erklärung gegeben wird. 


Zur Belegung der Funktionstasten: 

Die folgende GET-Schleife dient der Belegung bzw. -abfrage der 
Funktionstaste F2 (ASCII-Codezahlen 133-140 für die Funktions- 
tasten Fl, F2, ..., F8): 


500 PRINT "TASTE F2 DRUECKEN" Das Programm fährt nur 
510 GET E$: IF E$="" THEN 510 dann fort, wenn die 
520 IF E$<>CHR$(134) THEN 510 Funktionstaste F2 

530 PRINT "F2 WURDE GEDRUECKT'" gedrückt wurde. 

540 ... 


3.1.4 Programm mit Unterprogramm 


Die Verwendung von Unterprogrammen bietet entscheidende vVor- 

teile: 

- Ein in Unterprogramme gegliedertes Programm ist stets besser 
lesbar als ein ungegliedertes Gesamtprogramm. 

- Einen an mehreren Stellen im Programm benötigten Ablauf muß 
man nır e i nma 1 als Unterprogramm codieren. 

- Oft benötigte Verfahren können gesammelt und bei Bedarf im 
neuen Programm wie Ba us t ei ne eingesetzt werden. 

- Bei größeren Vorhaben können Teilabläufe von verschiedenen 
Personen getrennt entwickelt und dann zu einem Pro- 
grammkomplex zusammengesetzt werden. 

In BASIC kann man Unterprogramme durch die Anweisungen GOSUB 

und RETURN oder durch Funktionen verwirklichen. 
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3.1.4.1 Unterprogramme mit GOSUB und RETURN 


Programm DEMO-UPRO1 demonstriert, wie ein ei nma | codier- 
tes Unterprogramm (Zeilen 1000, 1010) zwei ma |] aufgeru- 
fen wird (Zeilen 140 und 180). Zu trennen ist also die Unter- 
programmcodierung (ein oder mehrere Zeilen mit RETURN am Ende) 
einerseits und der Unterprogrammaufruf (durch GOSUB) anderer- 
seits. In BASIC ist das Unterprogramm immer Teil des Hauptpro- 
gramns. 

Zweck des Unterprogramms ist es, die jeweilige Tastatureingabe 
um 10 zu erhoehen. Da sich die Eingabe im Hauptprogramm zuerst 
in X und dann in Y befindet, ist vor jedem Unterprogrammaufruf 
die Eingabe einer Variablen namens PAR (Parameter) zuzuweisen, 
um dann das Unterprogramm mit GOSUB 1000 aufzurufen, die Er- 
höhung mit 1000 LET PAR=PAR+10 auszuführen, mit 1010 RETURN 
in die jeweilige Folgezeile 150 bzw. 190 zurückzukehren und im 
Hauptprogramm fortzufahren. Die etwas umständliche Anweisungs- 
folge "LET PAR=X : GOSUB 1000 : LET X=PAR' ist erforderlich, 
da ein Unterprogrammaufruf wie etwa "GOSUB(X) 1000' mit einer 
tatsächlichen Parameterübergabe in BASIC nicht Standard ist. 
Mit SIMON's BASIC können wir Unterprogramme etwas komfortabler 
programmieren (vgl. Abschnitt 3.10.4). 


Codierung zu DEMO-UPRO1I: PAP zu DEMO-UPRO1: 
100 REM ======PROGRAMM DEMO-UPRO1 1 
110 PRINT "EIN UNTERPROGRAMM ZWEIMAL AUFRUFEN." 

120 INPUT "WERT VON X <- ":X 

130 REM *%*ERSTER UNTERPROGRAMM-AUFRUF*kakakakeakakick 
140 LET PAR = X: GOSUB 1000 

150 LET X = PAR: PRINT "X UM 10 ERHOEHT -> ":X 

160 INPUT "WERT VON Y <- ";Y 

170 REM ***ZWEITER UNTERPROGRAMM-AUFRUF**tkiskisktek 
180 LET PAR = Y: GOSUB 1000 

190 LET Y = PAR: PRINT "Y UM 10 ERHOEHT -> ";Y 

200 PRINT "ENDE.": END 

210 : 

220 REM :**UNTERPROGRAMM 'ERHOEHEN 'skakakakakakskakakakkainkek 
1000 LET PAR = PAR + 10 

1010 RETURN 


Ausführung zu DEMO-UPROI1: 


EIN UNTERPROGRAMM ZWEIMAL AUFRUFEN. 
WERT VON X <- 28 

X UM 10 ERHOEHT -> 38 

WERT VON Y <- 77777 

Y UM 10 ERHOEHT -> 77787 

ENDE, 


Die Anweisung 140 GOSUB 1000 merkt sich die Folgezeile 150 als 
Rückkehradresse und verzweigt nach Zeile 1000 zum dort anfang- 
enden Unterprogramm. Die Anweisung 1010 RETURN beendet das Un- 
terprogramm und verzweigt zu der (zuletzt) gemerkten Rückkehr- 
adresse. Beispiele für Anweisungen zum Unterprogrammaufruf: 


UPRO- 





- 140 GOSUB 1000 unbedingter Aufruf 

- 140 IF A=3 THEN GOSUB 1000 numerisch bedingter Aufruf 
- 140 IF B$="JA" THEN GOSUB 1000 Text-bedingter Aufruf 

- 140 ON C GOSUB 1000,2000,3000 Fallabfrage mit Aufruf 
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3.1.4.2 Standardfunktionen und selbstdefinierte Funktionen 


Funktionen sind besondere Unterprogramme, die stets mit ihrem 
Namen aufgerufen werden. Für häufig wiederkehrende Probleme 
sind Funktionen standardmäßig vorgegeben und für spezielle Be- 
nutzerprobleme können sie vom Benutzer selbst definiert werden. 





Zwei Arten von Funktionen 


Das in Klammern hinter der Funktion geschriebene Argument kann 
eine Konstante (INT(9.7)), eine Variable (INT(Z)) oder ein be- 
liebiger Ausdruck sein (INT(9.7+2Z)). 


Programm DEMO-FUNKTIONI stimmt in der Ausführung mit Programm 
DEMO-UPRO1 überein, nicht aber in der BASIC-Codierung: Das in 
DEMO-UPRO1 mittels GOSUB und RETURN geschriebene Unterprogramm 
wird in DEMO-FUNKTIONI über eine benutzerdefinierte Funktion 
mit DEF FN programmiert. In der hierfür vorgesehenen Anweisung 
140 DEF FN ERHOEH(PAR)=PAR+10 
schreiben wir hinter FN den Funktionsnamen ERHOEH, gefolgt 
von einem Parameter PAR, dem das Ergebnis von PAR+10 zugewie- 
sen wird. PAR vertritt als formaler Parameter beim 
Unterprogrammaufruf den entspr. akt ue 1 1 en Parameter 
X (1. Aufruf: FN ERHOEH(X)) sowie Y (2. Aufruf: FN ERHOEH(Y)). 


Ausführung zum Programm: 


EINE FUNKTION SELBST DEFINIEREN 
UND DANN ZWEIMAL AUFRUFEN. 

WERT VON X <- 28 

X UM 10 ERHOEHT -> 38 

WERT VON Y <- 77777 

Y UM 10 ERHOEHT -> 77787 

ENDE. 
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—— en 5 DOT 
Codierung zu Programm DEMO-FUNKTIONI: 


100 REM ======PROGRAMM DEMO-FUNKTIONI 

110 PRINT "EINE FUNKTION SELBST DEFINIEREN" 

120 PRINT "UND DANN ZWEIMAL AUFRUFEN." 

130 REM ***FUNKTION DEFINIEREN***3k3ssteksiokssioksiakskikikk 
140 DEF FN ERHOEH(PAR) = PAR + 10 

150 : 

160 INPUT "WERT VON X <- "sX 

170 REM *%**ERSTER FUNKTIONS-AUFRUFFFAKKRERS SKK 
180 PRINT "X UM 10 ERHOEHT -> "; FN ERHOEH(X) 

190 INPUT "WERT VON Y <- "sY 

200 REM *%**ZWEITER FUNKTIONS-AUFRUFFKKk&t ko 
210 PRINT '"Y UM 10 ERHOEHT -> "; FN ERHOEH(Y) 

220 PRINT "ENDE.": END 


3.2 Drei Beispiele zur Programmiertechnik 


zu den in Abschnitt 1.3.7.4 dargestellten Programmiertechniken 
betrachten wir drei Beispiele: Menütechnik, Standardisierung 
und Verzweigungstechnik mit Wahrheitswerten. 


3.2.1 Strukturiert programmieren: Menütechnik 


Bei der Ausführung des Programms MENUEI werden dem Benutzer 
sieben Wahlmöglichkeiten am Bildschirm angeboten - vergleich- 
bar mit den Gängen eines Menüs auf der Speisekarte. Aus diesem 

Grunde spricht man in der DV vonder Menütechnik. 

Folgende Punkte kennzeichnen diese Technik: 

(1) Auswahl einer Tätigkeit aus dem Menü: 

Das Menü wird am Bildschirm gezeigt, bis der Benutzer eine 
gültige Auswahl getroffen hat (Unterprogramme 'GOSUB 1000' 
und 'GOSUB 2000' in Programm MENUEI). 

(2) Ausführung dieser Tätigkeit in einem Unterprogramm: 

Über eine Mehrseitige Auswahl als Fallabfrage wird ein Un- 
terprogramm aufgerufen (Anweisung 140 ON M GOSUB ...) , um 
die gewählte Tätigkeit dann auszuführen. 

(3) Wiederholtes Menüangebot mit Programmende über das Menü: 
Nach dieser Ausführung wird das Menü erneut gezeigt. Die 
Anweisung PRINT CHR$(147); löscht den Bildschirm. Abge- 
brochen wird der Programmlauf stets über das Menü (Wahl 7) 
bzw. über das Steuerprogramm (hier Zeile 150), nicht aber 
über ein Unterprogramnm. 


Die sieben Tätigkeiten KONTOSTAND, EINZAHLUNG,.. werden in den 
Zeilen 1030-1040 unter DATA gespeichert. Soll das Menüprogramm 
für andere Zwecke verwendet werden, müssen ausschließlich die- 
se Zeilen geändert werden. 
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Die Anweisungen READ mit DATA dienen der Speicherung programm- 
interner Daten. Jede READ-Anweisung rückt dabei einen Lese- 
zeiger um I weiter. Die Anweisung RESTORE setzt den Lesezeiger 
auf Ausgangsposition 1 zurück. Die Daten können auf beliebig 
viele DATA-Anweisungen verteilt werden; wesentlich ist allein 
die Reihenfolge: 10 DATA 4,7 entspricht 10 DATA 4, 11 DATA 7. 


1000 READ N Nach N wird die Ziffer 7 eingelesen. 
1010 FOR I=1I TON Nach M$ werden 7 Textworte eingelesen 
1011 READ M$(I) (M$ ist ein String-Array). 


1012 NEXT I 
Inhalt von M$: 


1030 DATA 7, KONTOSTAND KONTOSTAND 
1031 DATA EINZAHLUNG ‚„‚AUSZAHLUNG EINZAHLUNG 
1032? DATA NEUES KONTO, KONTO LOESCHEN AUSZAHLUNG 
1033 DATA GESAMTLISTE, PROGRAMMENDE NEUES KONTO 
KONTO LOESCHEN 
READ weist einer oder mehreren Variablen GESAMTLISTE 
Werte zu, die unter DATA gespeichert sind. PROGRAMMENDE 


Anweisungen READ und DATA zur Datenspeicherung im Programm 


Codierung zu Programm MENUEI: PAP zu MENUEI: 


100 REM ======PROGRAMM MENUEI 

110 PRINT '"MENUE-DEMO MIT WAHL IN DATA.": PRINT 

120 GOSUB 1000: REM MENUE-ANGEBOT EINLESEN 

130 GOSUB 2000: REM MENUE-WAHL BEREITSTELLEN 

140 ON M GOSUB 3000, 4000,5000,6000, 7000, 8000 , 9000 

150 IF M = 7 THEN PRINT "ENDE.": END 

160 INPUT ""WEITERMIT RETURN ";W$: PRINT CHR$(147);: GOTO 130 
170 : 

180 REM *%**MENUE-ANGEBOT NACH M$ LESEN FF 
1000 READ N: DIM M$(N) 

1010 FOR I = 1 TO N: READ M$(I): NEXT I 

1020 RETURN 

1030 DATA 7,KONTOSTAND,EINZAHLUNG, AUSZAHLUNG , NEUES KONTO 
1040 DATA KONTO LOESCHEN, GESAMTLISTE, PROGRAMMENDE 

1050 : 

1060 REM ***MENUE-AUSWAHL IN M BEREITSTELLEN PRRRRRSRRFRER 


2000 PRINT "-------- MENUE-ANGEBOT------ 
2010 FOR I = 1 TON: PRINT " "s1;" "sM$CI): NEXT I 
5920: PRINT. "azssseasanezen er eeen " 


2030 INPUT "MENUE-AUSWAHL TIPPEN: ";W$: LETM = VAL (W$) 
2040 IFM< > INT (M) THEN PRINT "GANZZAHLIG": GOTO 2000 
2050 IF M < 1 OR M > N THEN PRINT "AUSSERHALB": GOTO 2000 
2060 RETURN 


3000 PRINT "UNTERPROGRAMM ";M$(M): RETURN 
4000 PRINT "UNTERPROGRAM ";M$(M): RETURN 
5000 PRINT "UNTERPROGRAMM ";M$(M): RETURN 
6000 PRINT "UNTERPROGRAMM ";M$(M): RETURN 
7000 PRINT "UNTERPROGRAMM ";M$(M): RETURN 
8000 PRINT "UNTERPROGRAM ";M$(M): RETURN 
9000 PRINT "UNTERPROGRAMM ";M$(M): RETURN 
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Die Anweisung 

140 ON M GOSUB 3000,4000,5000,6000,7000,8000,9000 
ruft für M=1 das Unterprogramm ab Zeile 3000 auf, für M=2 das 
Unterprogramm ab Zeile 4000 usw, wobei als Rückkehradresse für 
die RETURNs die Zeile 140 gespeichert wird. Durch die Fehler- 
abfragen in Zeile 2040-2050 wird sichergestellt, daß in M tat- 
sächlich nur einer der ganzzahligen Werte 1,2,....,7 vorliegt. 


In Zeile 2030 wird die Menü-Auswahl des Benutzers bewußt nicht 
einer numerischen Variablen W, sondern einer Textvariablen W$ 
zugewiesen. Damit soll ein "Aussteigen' des Computers bei feh- 
lerhafter Eingabe verhindert werden. Mit dem Funktions-Aufruf 
VAL(W$) wird der Text in W$ in einen Zahlenwert umgewandelt. 


Ausführung zu Programm MENUEI: UNTERPROGRAMM AUSZAHLUNG 
WEITER MIT RETURN 
MENUE-DEMO MIT WAHL IN DATA. OO u MENUE-ANGEBOT------ 
1 KONTOSTAND 
---- MENUE-ANGEBOT------ 2 EINZAHLUNG 
1 KONTOSTAND 3 AUSZAHLUNG 
2 EINZAHLUNG 4 NEUES KONTO 
3 AUSZAHLUNG 5 KONTO LOESCHEN 
4 NEUES KONTO 6 GESAMTLISTE 
5 KONTO LOESCHEN 7  _PROGRAMMENDE 
6 GESAMILISTE nn 
7  PROGRAMMENDE MENUE-AUSWAHL TIPPEN: 7 
=---- UNTERPROGRAMM PROGRAMMENDE 
MENUE-AUSWAHL TIPPEN: 3 ENDE. 


3.2.2 Wirtschaftlich programmieren: Standardisierung 


In einer Kundendatei soll für jeden Kunden die NUMMER, der NA- 
ME und der UMSATZ gespeichert werden, in einer Artikeldatei zu 
Jedem Artikel die BEZEICHNUNG, der PREIS und die MENGE, ... Je 
nach Dateiart ist das Eingabeproblem ähnlich. Unwirtschaftlich 
wäre es, für jedes Problem je ein neues Programm schreiben zu 
müssen. Programm STANDARDI zeigt die Problemlösung über ein 
Programm auf. Zwei Variablenebenen werden 
dabei unterschieden: 


- Variablen mit beschreibenden Daten: 
Die Variablen ND$(), TD$() und LD() nehmen Angaben zu Namen, 
Datentypen und Längen der Daten auf. Diese Daten sind in der 
DATA-Zeile gespeichert. Bei Änderung ist somit nur die DATA- 
zeile zu überprüfen. 

- Variablen mit den eigentlichen Daten: 
Die Variable ID$() steht für den eigentlichen "Inhalt der zu 
verarbeitenden Daten', z.B. für die drei Artikelangaben '101 
GOLDEN DELICIOUS 3470.50'. 


3.2 Drei Beispiele der Programmiertechnik 125 


Die Anweisung 

250 DIM ND$(AD) 
richtet für die Variable ND$ drei 'Fächer' (da AD=3) zur spä- 
teren Speicherung von drei Strings ein. Diese Dimensionierung 
mittels DIM erklären wir in Abschnitt 3.6 ausführlich. 


Programm STANDARD! verdeutlicht das prinzipielle Vorgehen beim 
Arbeiten mit zwei Variablenebenen und ist je nach Anwendung zu 
ergänzen: so fehlt z.B. die Prüfung für das UMSATZ-Format 6.2 
(6 Stellen, 2 Dezimalstellen). 


Codierung zu Programm STANDARD]: 


100 REM ======PROGRAMM STANDARD1 
110 : 
120 REM ======VEREINBARUNGSTEIL 


130 REM AD: INTEGER (ANZAHL DER DATEN) 

140 REM ND$(): FELD (NAMEN DER DATEN) 

150 REM TD$(): FELD: (TYPEN DER DATEN) 

160 REM LD(): FELD (LAENGEN DER DATEN) 

170 REM ID$(): FELD (INHALT DER DATEN) 

180 REM BEI AENDERUNG NUR ZEILE 230 AENDERN 

190 REM (I=INTEGER, S=STRING UND R=REALZAHL) 

200 : 

210 REM ======ANWEISUNGSTEIL 

220 REM Pk*BEZEICHNUNGEN SPEICHERN *kkaakskikakakakickk 
230 DATA 3,NUMMER,I,3,NAME,S,10,UMSATZ,R,6.2 

240 REM PRKLESESCHLETFE*3okakakakskakskakakakaiakskatokskskakskaksiaksink 
250 READ AD: DIM ND$(AD),TD$(AD),LD(AD),ID$(AD) 

260 FOR Z = 1 TO AD: READ ND$(Z),TD$(Z),LD(Z): NEXT 2 
270 REM ®*EINGABESCHLEIFE?* 3 3kakakakakstakakaksiaksksekskakskaksikikik 
280 FOR Z = 1 TO AD 

290 PRINT ND$(Z);" - "»s INPUT ID$(Z): NEXT Z 
300 REM **<STRING-LAENGE PRUEFEN ALS BEISPIELF****** 
310 FOR Z = 1 TO AD 

320 IF TD$(Z) = "S" AND LEN (ID$(Z)) > LD(Z) THEN 340 
330 PRINT "FEHLERFREI: ";ID$(Z): GOTO 350 

340 PRINT "FEHLERHAFT: ";ID$(Z);'" UEBER "»1LD(Z);'" STELLEN." 
350 NEXT Z 

360 PRINT "ENDE.": END 


STANDARD1 enthält als Programmstrukturen drei Zählerschleifen, 
die hintereinander angeordnet sind. In der letzten Schleife 
ist eine zweiseitige Auswahl geschachtelt angeordnet. 


Ausführung zu Programm STANDARDI: 


NUMMER - ?101 
NAME _ ?GOLDEN DELICIOUS 
UMSATZ _ 273470.50 


FEHLERFREI: 101 

FEHLERHAFT: GOLDEN DELICIOUS UEBER 10 STELLEN. 
FEHLERFREI: 3470.50 

ENDE. 
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3.2.3 Einfach programmieren: Verzweigungstechnik 


Das Programm BOOLEAN! verwendet das Zeichen = zur Zuweisung 
und zum Vergleich. Das erste = in Zeile 120 bewirkt eine Wert- 
zuweisung: nach Bl wird das Ergebnis von X=Y zugewiesen. Dabei 
ist X=Y ein Vergleichsausdruck mit = als Vergleichszeichen und 
dem Vergleichsergebnis WAHR oder UNWAHR, das dann der Variab- 
len Bl zugewiesen wird. Bi steht für "Bedingung 1'. Der THEN- 
Zweig in Zeile 130 wird nur ausgeführt, wenn Bi den Wert WAHR 
hat. 

Variablen, die nur die Werte WAHR (bzw. TRUE) und UNWAHR (bzw. 
FALSE) annehmen können, nennt man boolesche Variablen. Damit 
wird der Mathematiker George Boole geehrt, der um 1850 die Lo- 
gik erforscht hat. Commodore-BASIC sieht den Datentyp BOOLEAN 
(vgl. Abschnitt 1.3.2.1) explizit nicht vor. Gleichwohl können 
wir diesen Typ wie in Programm BOOLEAN! gezeigt verwenden. 


Codierung zu BOOLEANI!I: Zwei Ausführungen zu BOOLEANI: 
ZWEI ZAHLEN EINGEBEN: 5 

100 REM ======PROGRAMM BOOLEANI ENDE. Z 

110 INPUT "ZWEI ZAHLEN EINGEBEN: ";X,Y 

120 LETBl =X=Y RUN 

1A " 

130 IF Bl An a BEIDE ZAHLEN GLEICH. ZWEI ZAHLEN EINGEBEN: 4,4 

140 PRINT "ENDE. : END BEIDE ZAHLEN GLEICH. 
ENDE. 


Vergleichsoperatoren =, >, >=, <, <= und<>: 


Vergleichen wir z.B. zwei Zahlen, werden die Vergleichser- 
gebnisse WAHR bzw. UNWAHR in Commodore-BASIC durch die Zahlen 
-1 (für WAHR) bzw. O0 (für UNWAHR) dargestellt. 

Das Programm BOOLEAN2 demonstriert dies. Neben = lassen sich 
auch die Vergleichszeichen >, >=, <, <= und <> einsetzen. 10>6 
z.B. ergibt den Wert WAHR bzw. -1 und 2<>2 den Wert 0. 


Codierung zu BOOLEAN2: Ausführung zu BOOLEARN2: 
100 REM ======PROGRAMM BOOLEAN2 DARSTELLUNG DES DATENTYPS 
110 PRINT "DARSTELLUNG DES DATENTYPS 'BOOLEAN'." WAHR BZW. TRUE ->-1 
120 PRINT "WAHR BZW. TRUE -> "53 3 UNWAHR BZW. FALSE -> O 


130 PRINT '"UNWAHR BZW. FALSE -> ";3 
140 PRINT "ENDE.": END 


4 ENDE. 


Logische Operatoren AND, OR und NOT: 


Das Programm BOOLEAN3 zeigt, wie mehrere Vergleichsbedingungen 
durch logische Operatoren (auch boolesche Operatoren genannt) 
verknüpft werden können: so durch AND (und), OR (oder) und NOT 
(nicht). AND, OR und NOT werden in der Booleschen Algebra zur 
Erklärung logischer Zusammenhänge verwendet. Die Grundlage da- 
zu bilden die sogenannten Wahrheitstafeln. 


1 AND LS 1 1 OR 1 = 1 NOT RE 0 
1 AND 8 = 0 i OR Bi = 1 NOT .0:= 1 
0 AND N 0 0 OR | 1 
0 AND 0 = 0 DOOR and 


wahrheitstafeln für logisch 'und', 'oder' sowie 'nicht' 
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Für X=1 und Y=0 ergibt der boolesche Ausdruck X AND Y den 
Wert FALSE bzw. 0 und X OR Y den Wert TRUE bzw. -1. Mehrere 
boolesche Operatoren können in einem Ausdruck auftreten. Zwei 
Beispiele hierzu: NOT(X OR Y) ergibt den Wert FALSE, während 
(X>-100)AND(X<100) den Wert TRUE ergibt. 

Logische Operatoren arbeiten stets nur mit den Zahlen 0 und 1. 


Codierung zu Programm BOOLEAN3: 


100 REM ======PROGRAMM BOOLEAN3 

110 INPUT "DREI WORTE EINTIPPEN: ";A$,B$,C$ 
120 LET Bl = A$ = B$ 
130 LET B2 = B$ = ($ 

140 IF Bl AND B2 THEN PRINT "ALLE DREI GLEICH." 

150 IF Bl OR B2 THEN PRINT "DIE ERSTEN ODER LETZTEN BEIDEN GLEICH." 
160 IF NOT B2 THEN PRINT "DIE LETZTEN BEIDEN UNGLEICH." 

170 PRINT "ENDE.": END 


Drei Ausführungen zu Programm BOOLEAN3: 


DREI WORTE EINTIPPEN: 1,2,1 
DIE LETZTEN BEIDEN UNGLEICH. 


ENDE. DREI WORTE EINTIPPEN: DM,DM,DM 
ALLE DREI GLEICH, 
RUN DIE ERSTEN ODER LETZTEN BEIDEN GLEICH, 


DREI WORTE EINTIPPEN: JA,NEIN,NEIN ENDE. 
DIE ERSTEN ODER LETZTEN BEIDEN GLEICH. 
ENDE. 


In Verzweigungen mittels IF werden oft Vergleichsoperatoren 

un d logische Operatoren gemeinsam benutzt. In der Anweisung 
570 IF (BETRAG>1000) AND (TAGE<8) THEN 700 

z.B. werden zuerst die Vergleichsoperatoren '> größer" sowie 

"< kleiner" ausgeführt, die -1 bzw. 0 als Ergebnisse liefern. 

Auf diese Vergleichsergebnisse wird sodann der logische Opera- 

tor "AND bzw." und) angewandt: 

- Für BETRAG=3000 und TAGE=2 erhalten wir IF (-1) AND (-1)... 
und dann IF (1111) AND (1111)... mit -1 als Binärzahl 1111; 
IF 1 THEN 700 wird in Commodore-BASIC als Vergleichsausdruck 
IF 1X>0 THEN 700 behandelt; wir erhalten IF -1I THEN 700 und 
es wird also nach Zeile 700 verzweigt. 

- Für BETRAG=3000 und TAGE=9 erhalten wir IF (-1) AND (0)..., 
dann IF (1111) AND (0000)..., dann IF O0 THEN 700. Mit der 
Anweisung IF 0<>0 THEN 700 wird nicht verzweigt, sondern 
mit der Folgzeile fortgefahren. 

Wichtig ist, daß in Commodore-BASIC die beiden Anweisungen 
... IF V THEN ... 
und 
... IF V<>0 THEN ... 

als gleichbedeutend verarbeitet werden. 


Commodore-BASIC stellt die Vergleichsergebnisse -1 bzw. 0 als 
Binärzahlen 1111 bzw. 0000 dar und führt jede Verknüpfung mit 
logisch AND bit we i se durch. In Abschnitt 3.5.3 gehen 
wir auf die bitweise Verarbeitung genauer ein. 
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Die drei Programmbeispiele BOOLEANI - BOOLEAN3 zeigen, daß in 
BASIC neben den Datentypen INTEGER (Ganzzahl), REAL (Dezimal- 
zahl) sowie STRING (Text, Zeichenkette) auch der Typ BOOLEAN 
(wahrheitswert) verwendet werden kann. Dabei sind zwei Punkte 
festzuhalten: 

Das Anweisungswort LET sollte stets beibehalten werden. Sicher 
ist 20 LET BI = X=Y besser lesbar als 20 Bi1=X=Y . Dennoch 
bewirken die Anweisungen dasselbe: vergleiche X mit Y und wei- 
se das Ergebnis WAHR bzw. UNWAHR als -1 bzw. 0 der booleschen 
Variablen Bil zu. 

Die Verwendung des in BASIC nur "um Verborgenen vorhandenen" 
Datentyps BOOLEAN eröffnet elegante Möglichkeiten zur Ablauf- 
steuerung über Verzweigungen und Schleifen. 


3.3 Textverarbeitung 


Mt Textverarbeitung ist hier nicht das kauf- 
männische Standard-Programmpaket gemeint (siehe dazu Abschnitt 
1.3.8.3), sondern das Zerlegen und Zusammenfügen einzelner Da- 
ten vom Typ 'Text' bzw. 'String'. Man spricht dabei häufig von 
Sstringverarbeitung. 


3.3.1 Stringoperationen im Überblick 





Funktionen zur Verarbeitung von Strings 
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BASIC stellt die Standardfunktionen LEN, LEFT$, RIGHT$, MID$, 
VAL, STR$, CHR$ sowie ASC bereit. 


Diese Stringoperationen wollen wir an Beispielen betrachten. 


3.3.2 Einige kleine Programmbeispiele 


Programm TEXTO dient dem Zweck, ein Zeichen 2$ in einem String 
bzw. Text E$ zu suchen. S dient als Merker bzw. Flagge (Flag). 
Durch MID$(E$,I,1) wird das 1., 2., ... Element des Texts E$ 
angesprochen und mit 2$ verglichen. 

Die Zählerschleife wird in jedem Fall über 320 NEXT I verlas- 
sen (Prinzip: nur e i n Schleifenausgang). 

Programm TEXTO umfaßt zwei Programmstrukturen: eine Wiederho- 
lungsstruktur (Zählerschleife) und eine Auswahlstruktur (zwei- 
seitige Auswahl). 


Codierung zu Programm TEXTO: 


100 REM ======PROGRAMM TEXTO 

110 PRINT "EIN ZEICHEN IN EINEM TEXT SUCHEN." 
120 : 

130 REM ======VEREINBARUNGSTEIL 


140 REM E$: STRING (EINGABETEXT BELIEBIG) 

150 REM Z$: STRING (ZU SUCHENDES ZEICHEN) 

160 REM S: INTEGER (STELLE MIT ZEICHEN) 

170 REM L: INTEGER (LAENGE DES TEXTES E$) 

180 REM I: LAUFVARIABLE FUER SCHLEIFE 

190 : 

200 REM ======ANWEISUNGSTEIL 

210 INPUT "TEXT EINTIPPEN: ";E$ 

220 INPUT '"ZU SUCHENDES ZEICHEN EINTIPPEN: ";Z$ 

230 IF LEN (Z$) < > 1 THEN 220: REM MEHR ALS 1 ZEICHEN 
240 LETL= LEN (E$): REM LAENGE VON E$ 

250 LET S = O0: REM ANFANGSWERT SETZEN 

260 REM *%**BEGINN DER SUCHSCHLEIFEFFFFFKKRKSSKKKKCK 

270 FOR I = 1 TOL 

280 PRINT I;". STELLE VON TEXT ";E$: REM KONTROLLAUSGABE 
290 IF MID$ (E$,I,1l) < > Z$ THEN 320: REM FALLS NICHT GEFUNDEN 
300 LET S = I: REM STELLE S MERKEN 

310 LET I = L: REM LAUFVARIABLE AUF ENDWERT SETZEN 

320 NEXT I 

330 REM ?*&**ENDE DER SUCHSCHLEIFEFFFFFRFKKRRICKKRRIKEK 

340 : 

350 PRINT : PRINT "SUCHERGEBNIS: " 

360 IF S = O THEN PRINT Z$;'" NICHT GEFUNDEN.'": GOTO 380 
370 PRINT Z$;" AN ",S;". STELLE IM STRING ";E$ 

380 PRINT "PROGRAMMENDE." 
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Ausführung zu Programm TEXTO: 


EIN ZEICHEN IN EINEM TEXT SUCHEN. 
TEXT EINTIPPEN: COMMODORE 

ZU SUCHENDES ZEICHEN EINTIPPEN: M 
l. STELLE VON TEXT COMMODORE 

2. STELLE VON TEXT COMMODORE 

3. STELLE VON TEXT COMMODORE 


SUCHERGEBNIS: 
M AN 3. STELLE IM STRING COMMODORE 
PROGRAMMENDE. 


In Programm TEXT] wird kein Zeichen, sondern ein String in ei- 
nem Text gesucht. Diese Anweisungsfolge wird häufig zusätzlich 
als INSTR-Funktion angeboten. 

Programmstrukturen: Zählerschleife und Einseitige Auswahl. 


Codierung zu Programm TEXT1: 


100 REM ======PROGRAMM TEXTI 

110 PRINT "EINEN STRING IN EINEM TEXT SUCHEN." 

120 INPUT "TEXT EINTIPPEN: ";E$ 

130 INPUT "ZU SUCHENDEN STRING EINTIPPEN: ";Z$ 

140 FOR I = 1TO (LEN (E$) - LEN (Z$) + 1) 

150 IF MID$ (E$,I, LEN (Z$)) = Z2$ THEN LETS =1I 
160 NEXT I 

170 IF S > O THEN PRINT Z$;' BEGINNT MIT STELLE ";S 
180 PRINT "ENDE.'": END 


Ausführungen zu Programm TEXT1: 


EINEN STRING IN EINEM TEXT SUCHEN. EINEN STRING IN EINEM TEXT SUCHEN. 
TEXT EINTIPPEN: COMMODORE TEXT EINTIPPEN: COMMODORE 

ZU SUCHENDEN STRING EINTIPPEN: MOD ZU SUCHENDEN STRING EINTIPPEN: MODE 
MOD BEGINNT MIT STELLE 4 ENDE. 

ENDE. 


Programm TEXT2 kehrt den Text T1$ zu T2$ um. Dabei wird in ei- 
ner Zählerschleife mit Schrittweite -1 das letzte, vorletzte, 
ec. Element von T1$ entnommen und an den String T2$ angehängt. 
Dazu wird vor dem Schleifeneintritt ein Leerstring T2$ erzeugt 
(Zeile 210), an den dann wiederholt Zeichen angehängt werden. 


PROGRAMM ZUM UMKEHREN VON TEXT. PROGRAMM ZUM UMKEHREN VON TEXT. 
BELIEBIGEN TEXT EINTIPPEN: COMMODORE BELIEBIGEN TEXT EINTIPPEN: C 64 
l. SCHLEIFENDURCHLAUF: E 1. SCHLEIFENDURCHLAUF: 4 

2. SCHLEIFENDURCHLAUF: ER 2. SCHLEIFENDURCHLAUF: 46 

3. SCHLEIFENDURCHLAUF: ERO 3. SCHLEIFENDURCHLAUF: 46 

4. SCHLEIFENDURCHLAUF: EROD 4. SCHLEIFENDURCHLAUF: 46 C 

5. SCHLEIFENDURCHLAUF: ERODO 

6. SCHLEIFENDURCHLAUF: ERODOM C 64 UMGEKEHRT ZU 46 C 

7. SCHLEIFENDURCHLAUF: ERODOMM 

8. SCHLEIFENDURCHLAUF: ERODOMMO 

9. SCHLEIFENDURCHLAUF: ERODOMMOC 


Ausfüh Programm TEXT2 
COMMODORE UMGEKEHRT ZU ERODOMMOC ustuhrung zu 9 


3.3 Textverarbeitung 131 


Codierung zu Programm TEXT2: 


100 REM ======PROGRAMM TEXT2 
110 PRINT "PROGRAMM ZUM UMKEHREN VON TEXT." 
120 REM ======VEREINBARUNGSTEIL 


130 REM T1$: TEXT (AUSGANGSTEXT) 

140 REM T2$: TEXT (UMKEHRTEXT) 

150 REM L: INTEGER (LAENGE VON T1$) 

160 REM I: INTEGER (LAUFVARIABLE) 

170 :; 

180 REM ======ANWEISUNGSTEIL 

190 INPUT "BELIEBIGEN TEXT EINTIPPEN: ";T1$ 


200 LETL = LEN (T1$): REM LAENGE DES STRINGS TI$ 
210 LET T2$ = "": REM STRING T2$ ALS LEERSTRING MIT LAENGE=O 
220 FOR I = L TO 1 STEP - 1: REM ZAEHLEN VON L BIS 1 HINUNTER 


230 LET T2$ = T2$ + MID$ (T1$,I,1): REM I. ZEICHEN AN T2$ ANHAENGEN 
240 PRINT L - I + 1;'". SCHLEIFENDURCHLAUF: ";T2$: REM KONTROLLAUSGABE 
250 NEXT I: REM NAECHSTES ZEICHEN NEHMEN 

260 PRINT : PRINT T1$;'' UMGEKEHRT ZU ";T2$ 

270 END 


Programm TEXT3 wendet die Funktion STR$ zur Umwandlung einer 
zahl 2 in einen String 2$ an, um die einzelnen Ziffern ausein- 
anderziehen zu können. 

Programm TEXT4 dient zum Unterstreichen von Text. 


Codierung zu Programm TEXT3: Ausführung zu Programm TEXT3: 
100 REM ======PROGRAMM TEXT3 ZIFFERN AUSEINANDERZIEHEN. 
110 PRINT "ZIFFERN AUSEINANDERZIEHEN,." ZAHL EINGEBEN: 63792.537 
120 INPUT "ZAHL EINGEBEN: ";Z 63792,.537 


130 LET Z$ = STR$ (2) 
140 FOR I = 1 TO LEN (Z$) 
150 PRINT MID$ (Z2$,1,1);" "; 


160 NEXT I 

170 END 

Codierung zu Programm TEXT4: Ausführung zu Programm TEXT4: 
100 REM ======PROGRAMM TEXT4 TEXT UNTERSTREICHEN. 

110 PRINT "TEXT UNTERSTREICHEN." TEXT EINGEBEN: 

120 PRINT "TEXT EINGEBEN:" ?DER C 64 VON COMMODORE 
130 INPUT T$ 

140 PRINT : PRINT T$ DER C 64 VON COMMODORE 


150 FORI=1TO LEN (TS) 00 nn 
160 PRINT "-"; 

170 NEXT I 

180 END 
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Durch Programm TEXT5 wird Text rechtsbündig ausgegeben. Hierzu 
wird ein String L$ mit Z Blancs bzw. Leerstellen aufgebaut, an 
den der Eingabetext E$ angehängt wird, um mit RIGHT$(G$,2) die 
2 rechtsstehenden Zeichen auszugeben. 

Programm TEXT6 erweitert eine Ganzzahl 2% - in einen String 2$ 
umgewandelt - um führende Nullen. 


Codierung zu Programm TEXT5: 


100 REM ======PROGRAMM TEXTS5 
110 PRINT "TEXT RECHTSBUENDIG AUSGEBEN.": PRINT 
120 PRINT "STELLENANZAHL BZW. ZEILENBREITE:" 


130 INPUT Z 
140 FOR I=1T02: LETL$ = L$ +" ": NEXTI 
150 PRINT "TEXTEINGABE (UNTER ";2;" STELLEN) :" 
160 INPUT E$ 


170 LETG$ = L$ + E$ 
180 LET A$ = RIGHT$ (G$,Z) 
190 PRINT : PRINT "TEXTAUSGABE RECHTSBUENDIG:" 


200 PRINT A$ 

210 END 

Ausführung zu Programm TEXTS5: Ausführung zu Programm TEXT6: 

TEXT RECHTSBUENDIG AUSGEBEN. ZAHL UM FUEHRENDE NULLEN ERWEITERN. 
Ä ANZAHL DER STELLEN INSGESAMT: 10 

STELLENANZAHL BZW. ZEILENBREITE: GANZZAHL: : 12 

?30 0000000012 

TEXTEINGABE (UNTER 30 STELLEN): ENDE. 


?COMMODORE 64 


TEXTAUSGABE RECHTSBUENDIG: 
COMMODORE 64 


Codierung zu Programm TEXT6: 


100 REM ======PROGRAMM TEXT6 
110 PRINT "ZAHL UM FUEHRENDE NULLEN ERWEITERN." 
120 INPUT "ANZAHL DER STELLEN INSGESAMT: ";A 


130 INPUT "GANZZAHL: : 527 
140 LET Z$ = STR$ (Z) 
150 LET Z$ = RIGHT$ (Z$, LEN (Z$) - 1) 


160 LET Z$ = RIGHT$ (''000000000000000" + Z$,A) 
170 PRINT Z$ 
180 PRINT "ENDE.'": END 


Programm TEXT7 demonstriert die Funktion LEFT$, um Text durch 
Blancs zu erweitern (Anwendung z.B., um eine feste Datensatz- 
länge einer Datei zu erreichen). 


Ausführung zu Programm TEXT?7: 


STRING MIT BLANCS ERWEITERN. STRING MIT BLANCS ERWEITERN. 

ANZAHL DER STELLEN INSGESAMT: 15 ANZAHL DER STELLEN INSGESAMT: 20 
ZU ERWEITERNDER STRING: 12.5 ZU ERWEITERNDER STRING: 17150 
-->12.5 <-- -->17150 I 


ENDE. ENDE. 
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Codierung zu Programm TEXT7: 


100 REM ======PROGRAMM TEXT7 

110 PRINT "STRING MIT BLANCS ERWEITERN." 

120 INPUT "ANZAHL DER STELLEN INSGESAMT: ";A 
130 INPUT "ZU ERWEITERNDER STRING: ",5$ 
140 FOR I = 1 TO A: LETB$ = B$ + " ": NEXTI 
150 LET S$ = LEFT$ (S$ + B$,A) 

160 PRINT "--2";5$;"<--" 

170 PRINT "ENDE.": END 


3.3.3 Datumsangaben verarbeiten 


Angaben zum Datum werden so oft verarbeitet, daß man fast von 
einem eigenen 'Datentyp' sprechen kann. Programm DATUMINTI be- 
reitet ein Datum zum Sortieren auf: Das Eingabeformat 'Tag-Mo- 
nat-Jahr' wird umgekehrt zum Format "Jahr-Monat-Tag' und könn- 
te so leicht - in eine Ganzzahl umgewandelt - sortiert werden. 


Codierung und Ausführung zu Programm DATUMINTI: 


100 REM ======PROGRAMM DATUMINTI 

110 PRINT "DATUM ALS INTEGER-ZAHL ZWECKS SORTIEREN." 
120 INPUT "DATUM IM FORMAT TT.M.JJ: ";D$ 

130 LET T$ = LEFT$ (D$,2) 

140 LETM$ = MID$ (D$,4,2): LET J$ = RIGHT$ (D$,2) 
150 LET DI$ = J$ + M$ + T$ 

160 PRINT "INTEGERZAHL "UMGEKEHRT': ";DI$ 

170 PRINT "ENDE.": END 


DATUM ALS INTEGER-ZAHL ZWECKS SORTIEREN. 
DATUM IM FORMAT TT.MM.JJ: 31.08.44 
INTEGERZAHL "UMGEKEHRT': 440831 

ENDE. 


3.3.4 Teilstrings aufbereiten 


Aus Gründen der Speicherplatzersparnis speichert man die Sätze 
einer Datei oft als Strings ab, wobei die Satzkömponenten z.B. 
durch das Zeichen ";'" voneinander getrennt werden. Programm 
ETIKETTENI demonstriert, wie aus dem String S$ die Teilstrings 
T$ zu einem Drucketikett aufbereitet werden. Das Beispiel be- 
zieht sich also auf eine Artikeldatei mit Sätzen (Strings S$), 
die aus jeweils 6 Datenfeldern (Teilstrings T$) bestehen. Die 
Abfrage in Zeile 240 vergleicht mit CHR$(59) und damit mit ";" 
(59 als Codezahl für das Semikolon im ASCII); man könnte eben- 
so schreiben: 260 IF (MID$(S$,I,1)=";") OR ... 
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Codierung zu Programm ETIKETTEN]: 


100 REM ======PROGRAMM ETIKETTENI 

110 PRINT "TEILSTRINGS AUS EINEM STRING ENTNEHMEN" 
120 PRINT "UND AUS DRUCKETIKETT AUSGEBEN." 

130 : 

140 REM ======VEREINBARUNGSTEIL 

150 REM S$: STRING (DATENSATZ MIT ; GETRENNTEN DATENFELDERN) 
160 REM NS: INTEGER (LAENGE VON S$) 

170 REM T$: STRING (TEILSTRING MIT EINEM DATENFELD) 
180 REM NT: INTEGER (LAENGE VON T$) 

190 : 

200 REM ======ANWEISUNGSTEIL 

210 PRINT "STRING MIT ; ALS TRENNUNGSZEICHEN:" 

220 INPUT S$: LETNS = LEN (S$) 

230 PRINT : PRINT "AUSGABE ALS ETIKETT: " 

240 REM *%**TRENNUNGSZEICHEN ; SUCHENFFRFRRRRRRRRER 
250 FOR I = 1 TONS | 

260 IF ( MID$ (S$,I,1) = CHR$ (59)) OR (NS = I) THEN LETNT = I:I = NS 
270 NEXT I 

280 REM ***TEILSTRING T$ ENTNEHMENFFFRRRRRRRRRRICKEK 
290 LET T$ = LEFT$ (S$,NT - 1) 

300 PRINT" "sT$ 

310 REM *%**GESAMTSTRING S$ UMD T$ KUERZENFFFFRRRRRK 
320 LETNS = NS - NT 

330 IF NS = O THEN 350 

340 LET S$ = RIGHT$ (S$,NS): GOTO 250 

350 PRINT "ENDE.": END 


Ausführung zu Programm ETIKETTEN!: 


TEILSTRINGS AUS EINEM STRING ENTNEHMEN 

UND AUS DRUCKETIKETT AUSGEBEN. 

STRING MIT ; ALS TRENNUNGSZEICHEN: 
?1007;DISKETTE;5.25;SS/DD 48 TPI;10 STK.;48 DM; 


AUSGABE ALS ETIKETT: 
1007 
DISKETTE 
5.25 
SS/DD 48 TPI 
10 STK. 
48 DM 
ENDE. 


3.3.5 Stringvergleich mit Joker-Zeichen 


Programm JOKER1 veranschaulicht vier wesentliche Möglichkei- 
ten, einen String "MWST" als Ordnungsbegriff mit je einem wei- 
teren String als Suchbegriff zu vergleichen. 

1) Verwendet man als Joker das Zeichen = ,„ wird M=, MW= wie 
MWS= jeweils als 'gleich' mit MWST erkannt. Das = ersetzt also 
eine Zeichenfolge. Insbesondere bei längeren Strings spart man 
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sich bei Verwendung des Jokers = viel Tipparbeit. 

2) Das Joker-Zeichen ? ersetzt genau ein Einzelzeichen. MW?T 
wie auch M??T werden so als 'gleich' mit MWST erkannt. 

3) Der Gesamtvergleich vergleicht beide Strings Zeichen für 
Zeichen in voller Länge. 

4) Der Teilvergleich faßt den Suchbegriff als Teilmenge auf. 


Ausführung zu Programm JOKER!: 


VIER ARTEN DES STRINGVERGLEICHS. 

--> ZU PRUEFENDER ORDNUNGSBEGRIFF: MWST 
--> SUCHBEGRIFF (O FUER ENDE): MW= 
VERGLEICH MIT JOKER '=': MW= IN MWST 

--> SUCHBEGRIFF (0 FUER ENDE): MW?? 
VERGLEICH MIT JOKER '?': MW?? GLEICH MWST 
--> SUCHBEGRIFF (O FUER ENDE): MW?T 
VERGLEICH MIT JOKER '?': MW?T GLEICH MWST 
--> SUCHBEGRIFF (O FUER ENDE): MW 
TEILVERGLEICH: MW LINKS IN MWST 

--> SUCHBEGRIFF (O FUER ENDE): MWST 
GESAMTVERGLEICH: MWST GLEICH MWST 
TEILVERGLEICH: MWST LINKS IN MWST 
VERGLEICH MIT JOKER '?': MWST GLEICH MWST 
-—-> SUCHBEGRIFF (O FUER ENDE): O 

ENDE. 


Codierung zu Programm JOKER!I: 


100 REM ======PROGRAMM JOKER1 

110 PRINT "VIER ARTEN DES STRINGVERGLEICHS." 
120 : 

130 REM ======VEREINBARUNGSTEIL 


140 REM 0$: STRING (ORDNUNGSBEGRIFF) 

150 REM S$: STRING (SUCHBEGRIFF) 

160 REM NO: INTEGER (STELLENANZAHL VON O$) 
170 REM NS: INTEGER (STELLENANZAHL VON S$) 


180 REM S: INTEGER (STELLE BZW. MERKER) 
190 : 
200 REM ======ANWEISUNGSTEIL 


210 INPUT "--> ZU PRUEFENDER ORDNUNGSBEGRIFF: ";0$: LET NO = LEN (0$) 
220 INPUT "--> SUCHBEGRIFF (O FUER ENDE): ";S$: LETNS = LEN (S$) 

230 LET S = 0: REM STELLE SOWIE FLAGGE 

240 IF S$ = "0" THEN PRINT "ENDE.": END 

250 REM tk GESAMTVERGLEICH *rkaskaskseksaisfgtsigtsiglgisigisigisioiofsioksieieisfeisieksileisiekhk 
260 LET SI$ = LEFT$ (S$ + " ",NO) 

270 IF S1$ = 0$ THEN 290 

280 GOTO 310 

290 PRINT "GESAMTVERGLEICH: ";S$;'" GLEICH ";0$ 

300 REM sk TEILVERGLEICH *3katakakaksistakseksfsieksiaksisietsfgiaisieksigieisfeksifekefgieisieiekaieiek 
310 IF S$ < > LEFT$ (0$,NS) THEN 340 

320 PRINT "TEILVERGLEICH: ";S$;'" LINKS IN ";0$ 

330 REM  *** VERGLEICH MIT JOKER = akakakaksaksistaksttaisieksigiaisiniaigisieiaksisieksikiksiek: 
340 FOR I = 1 TONS 

350 IF "="= MID$ (S$,I,1l) THEN LETS = I: LETI=NS 

360 NEXT I 

370 IF S = O THEN 410 
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380 IF LEFT$ (S$,S - 1) < > LEFT$ (0$,S - 1) THEN 410 

390 PRINT "VERGLEICH MIT JOKER '=': ";S$;" IN ";0$ 

400 REM elek VERGLEICH MIT JOKER ? 3kakakakskakaksakskasiakskakatstsfgiaisiakstefgkaksieiaksiefkik: 
440 LETS = 1: REM S ALS FLAGGE 

420 FOR I = 1 TO NO 

430 IF "?" = MID$ (S$,I,1) THEN 450 

440 IF MID$ (S$,I,1) < > MID$ (0$,1,1) THEN LET S = 0: LET I = NO 
450 NEXT I 

460 IF S = O THEN 480 

470 PRINT "VERGLEICH MIT JOKER '?': "3S$;'" GLEICH ";0$ 

480 GOTO 220 


3.3.6 Verschlüsselung zwecks Datenschutz 


In Klartext gespeicherte Daten kann jeder lesen, verschlüssel- 
te Daten hingegen zumindest nicht so leicht. Die Kryptographie 
als Lehre von der Textverschlüsselung kennt drei wichtige Ver- 
fahren: Die Umcodierung (z.B. Information im ASCII schreiben), 
die Versatz-Verfahren und die Ersetzungs-Verfahren. Versatz 
bedeutet, daß das zugrundeliegende Alphabet versetzt und umge- 
stellt wird; ein Beispiel haben wir mit dem 'von hinten nach 
vorne schreiben' in Programm TEXT2 (Abschnitt 3.3.2) schon be- 
handelt. Bei den Ersetzungs-Verfahren wird das zugrundeliegen- 
de Alphabet ersetzt; das Programm VERSCHLUESSELUNG zeigt ein 
einfaches auf Julius Cäsar zurückgehendes Verfahren. Wie geht 
man dabei vor? Jedes Zeichen des Klartextes E$ wird durch das 
S-te nachfolgende Zeichen ersetzt. Dabei geben die Codezah- 
len des ASCII die Reihenfolge vor. Die ASC-Funktion stellt uns 
mit dem Aufruf ASC(MID$(E$,I,1)) die Codezahl des I. Zeichens 
im Klartext E$ zur Verfügung; addieren wir S hinzu, so kommen 
wir zur Codezahl des verschlüsselten Zeichens. 


Ausführung zu Programm VERSCHLUESSELUNG: 


TEXTVERSCHLUESSELUNG 'ERSETZUNG CAESAR'. TEXTVERSCHLUESSELUNG 'ERSETZUNG 


EINGABETEXT: 1298560 DM BILANZSUMME EINGABETEXT: COMMODORE 64 
SCHLUESSEL: 10 SCHLUESSEL: 2 

1. VERSCHLUESSELUNG: 1. VERSCHLUESSELUNG: 
AUSGABETEXT: AUSGABETEXT: 

;<CB?@: *NW*LSVKXd ]_WWO EQOOQFOTG"86 

2. ENTSCHLUESSELUNG: 2. ENTSCHLUESSELUNG: 
EINGABETEXT JETZT: EINGABETEXT JETZT: 
;<CB?@:*NW*LSVKXd ]_WWO EQOOQFQTG"86 

AUSGABETEXT WIEDERUM: AUSGABETEXT WIEDERUM: 
1298560 DM BILANZSUMME COMMODORE 64 


ENDE. ENDE. 
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Codierung zu Programm VERSCHLUESSELUNG: 


100 REM ======PROGRAMM VERSCHLUESSELUNG 

110 PRINT "TEXTVERSCHLUESSELUNG "ERSETZUNG CAESAR'." 
120 : 

130 REM ======VEREINBARUNGSTEIL 


140 REM E$: STRING (EINGABETEXT) 

150 REM A$: STRING (AUSGABETEXT) 

160 REM S: INTEGER (SCHLUESSEL ZUM ERSETZEN) 
170 REM H: INTEGER (ASCII-CODEZAHL) 

180 : 

190 REM ======ANWEISUNGSTEIL 

200 INPUT. "EINGABETEXT: ";E$ 

210 INPUT "SCHLUESSEL: ";S 

220 PRINT : PRINT "1. VERSCHLUESSELUNG: " 

230 GOSUB 330: REM UPRO 'ERSETZUNG' 

240 PRINT "AUSGABETEXT: ": PRINT A$ 

250 PRINT : PRINT "2. ENTSCHLUESSELUNG: " 

260 LET E$ = A$: LETTS= -S 

270 PRINT "EINGABETEXT JETZT:": PRINT E$ 

280 GOSUB 330: REM 2. AUFRUF VON UPRO 'ERSETZUNG' 
290 PRINT "AUSGABETEXT WIEDERUM:": PRINT A$ 

300 PRINT "ENDE.": END 

310 : 

320 REM *%**UNTERPROGRAMM "ERSETZUNG ! Hrkakakakakskkakaiokikikck 
330 LET A$ = "" 

340 FOR I = 1 TO LEN (E$) 

350 LETH= ASC ( MID$ (E$,I,1)) +S 

360 IFH > 127 THEN LETH=H - 127 

370 IFH<OTHENH=H + 127 

380 LET A$ = A$ + CHR$ (H) 

390 NEXT I 

400 RETURN 

41lO REM ***ENDE UNTERPROGRAMMKk3soksckkkiekkikckikeickikikkk 


3.3.7 Ein Spiel zum Erraten von Text 


Im WORTSPIELI muß ein Wort erraten werden, von dem zuerst nur 
die Länge bekannt ist. Wird ein passendes Zeichen getippt, So 
setzt das Programm dieses Zeichen an die zugehörige Stelle. 
Die bei der Ausführung zum Programm WORTSPIELI untereinander- 
stehenden Buchstaben E,B,A,R,I ... wurden über Tastatur einge- 
tippt. COMMODORE 64 als zu erratendes Wort haben wir der Ein- 
fachheit halber eingetippt. Man könnte es z.B. in einer Datei 
zusammen mit weiteren Worten speichern und zufällig auswählen. 
Zur Codierung von WORTSPIEL]: 

Die Zählerschleife in 120 baut einen Ausgabestring A$ mit zu- 
nächst ausschließlich nur Sternen auf. In 160 wird eine Einga- 
be (e i n Zeichen) für E$ erwartet. Je nach Übereinstimmung 
dieses Zeichens mit dem ersten, dem letzten oder einem sonsti- 
gen Zeichen im Ratewort W$ wird das erste Sternchen (in Zeile 
190), das letzte Sternchen (in 200) oder ein mittleres Stern- 
chen (in 210) vom Ausgabetext A$ durch E$ ersetzt, d.h. E$ mit 
A$ neu verkettet. 

Anstelle von INPUT könnte man auch eine Warteschleife mit GET 
programmieren (vgl. Abschnitt 3.1.3.7). 
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Codierung zu Programm WORTSPIEL1: 


100 REM ======PROGRAMM WORTSPIEL1 
110 PRINT "ZU ERRATENDES WORT:": INPUT W$: LET LW = LEN (W$) 
120 LET A$ = "": FOR I = 1 TO LW: LET A$ = A$ + "x". NEXT I 


130 PRINT CHR$ (147);: PRINT "NUN EINZELZEICHEN TIPPEN:": PRINT 
140 PRINT A$;" ", 

150 IF A$ = W$ THEN 240 

160 INPUT E$ 

170 FORI=1TOIW 

180 IF MID$ (W$,I,1) < > E$ THEN 220 

190 IF I= 1 THEN LETA$ =E$ + RIGHT$ (A$,LW - I): GOTO 220 
200 IF I =LW THEN LETA$ = LEFT$ (A$,I - 1) + E$: GOTO 220 
210 LET A$ = LEFT$ (A$,T - 1) + E$ + RICHT$ (A$,LW - I) 

220 NEXT I 

230 GOTO 140 

240 PRINT "SPIELENDE.": END 


Zwei Ausführungen zu Programm WORTSPIEL]1: 


ZU ERRATENDES WORT: ZU ERRATENDES WORT: 
?COMMODORE64 ?MIKRO 

NUN EINZELZEICHEN TIPPEN: NUN EINZELZEICHEN TIPPEN: 
eakakaakakkaakck — 0) ka — K 
KOKKOKOEKEK 4 KKKKk M 
KOKKOFOKKKL A M#Kk*k  W 
KOKKORORERL — C MrKkk 0 
COF*OFOF**4  E M*K*0 U 
CO**O*O*E*4 — F M*K*0 I 
COF*OFO*E*4L — M MIK*O _R 
COMMO*FO*E*4 MIKRO SPIELENDE. 
COMMO*O*E*4  _R 

COMMO*ORE*4 6 

COMMO*ORE64 D 

COMMODORE64 SPIELENDE. 


Das Programm WORTSPIEL1 umfaßt eine nicht-abweisende Schleife, 
die eine Zählerschleife einschachtelt, in der eine mehrseitige 
Auswahl ebenfalls geschachtelt angeordnet ist. 


3.4 Bildschirmausgabe und Druckausgabe 


3.4.1 Steuerung des Cursors am Bildschirm 


Programm CURSORPOSITIONI! zeigt, wie der Cursor als blinkendes 
Zeichen am Bildschirm frei positioniert werden kann. Das Aus- 
führungsbeispiel positioniert das Zeichen "+" in Zeile 4 und 
Spalte 23. 
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Codierung zu Programm CURSORPOSITION!: 


100 REM ======PROGRAMM CURSORPOSITIONI 

110 PRINT "CURSOR UEBER STEUERZEICHEN POSITIONIEREN." 
120 : 

130 REM ======VEREINBARUNGSTEIL 


140 LET C$ = CHR$ (147): REM BILDSCHIRM SAUBER 

150 LET CU$ = CHR$ (17): REM CURSOR NACH UNTEN 

160 REM CR$=CHR$(29) : REM CURSOR NACH RECHTS 

170 FOR I - 1 TO 6: REM STRINGS FUER CURSORSCHRITTE 
180 LET CU$ = CU$ + CU$: LET CR$ = CR$ + CR$: NEXT I 
190 : 

200 REM ======ANWEISUNGSTEIL 

210 INPUT "ZEILE (0-24 OBEN -> UNTEN)"sZ 

220 INPUT "SPALTE (0-39 LINKS -> RECHTS)";S 

230 PRINT C$; 

240 PRINT LEFT$ (CU$,Z); LEFT$ (CR$,S);"+" 

250 END 


Bei einer Unterteilung des Bildschirms in 25 waagerechte Zei- 
len und 40 senkrechte Spalten kann dieser maximal 1000 Zeichen 
darstellen. Dementsprechend gibt es 1000 verschiedene Cursor- 
positionen. 

Die Zeilen werden von 00 01 02 03 EITRE 37 38 39 
0 bis 24 und die Spal- 
ten von 0 bis 39 ge- 


zählt. 
Den Cursor können wir Cursorposition: 
durch Steuerzeichen an zeile 2, Spalte 37 


jede beliebige Position 
bringen. 





Druckbare Zeichen 


ziffer, Buchstabe, Sonderzeichen: Grafik-Zeichen: 

2.B. CHR$(77) für Buchstabe M z.B. CHR$(115) für 
CHR$(63)} für Fragezeichen CHR$(113) fur 
CHR$(32) für Leerstelle CHR$(127) für 
Wi .chr e aree Eie Zeichen 

Cursor- Drucker- Sonst. Ausgabesteuerung 
steuerung: steuerung: sowie interne Kontrolle: 

CHR$(19) Home abhängig CHR$(142) Großbuchst. 

CHR$(17) Cursor runter vom CHR$(14) Kleinbuch- 

CHR$(145) Cursor hoch jeweiligen stabe um- 

CHR$(29) Cursor rechts Drucker schalten 

CHR$(157) Cursor links CHR$(133)-CHR$(140) für 

CHR$(13) Wagenrücklauf Funktionstasten 1-8. 

CHR$(18) Revers ein CHR$(44) Farbe schwarz 


Druckbare Zeichen und Steuerzeichen mit Beispielen 
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Druckbare und nicht-druckbare Zeichen: 


Es gibt druckbare Zeichen und solche Zeichen, die eine ganz 
bestimmte Funktion zur Steuerung eines Ausgabegerätes auslösen 
(Zeichen CHR$(13) mit ASCII-Codezahl 13 löst RETURN aus), oder 
die der internen Kontrolle dienen. 


Jedem Steuerzeichen ist im ASCII-Code eine Zahl zugeordnet. 
Durch die Anweisung PRINT CHR$(Codezahl) können wir ein be- 
stimmtes Steuerzeichen absenden bzw. "ausgeben'. Geben wir an 
der Tastatur PRINT CHR$(19) ein, wird der Cursor in die obe- 
re linke Bildschirmecke gebracht. Mit PRINT CHR$(147) können 
wir zusätzlich noch den Bildschirm löschen. 

Nun zu Programm CURSORPOSITIONI! im einzelnen: 

140 LET C$=CHR$(147) weist das Steuerzeichen "Home sowie Bild- 
schirm löschen' der Variablen C$ zu (C wie Cursor). Wir können 
nun vereinfacht durch PRINT C$ den Bildschirm sauber machen. 
Entsprechend vereinbaren wir die Steuerzeichen CU$ (Cursor um 
eine Position nach unten) und CR$ (Cursor um eine Stelle nach 
rechts). 

PRINT CR$;5CR$;CR$;CR$; rückt den Cursor um vier Stellen nach 
rechts. Da dieses Vorgehen sehr umständlich ist, verketten wir 
in Zeile 180 die Variable CR$ zu einem 64-Zeichen-String. Mit 
PRINT LEFT$(CR$,4); bringen wir jetzt den Cursor um vier Stel- 
len und mit PRINT LEFT$(CR$,37); um 37 Stellen nach rechts. 
".„" am Ende der PRINT-Anweisung unterdrückt den anschließenden 
Wagenrücklauf bzw. RETURN, der Cursor verbleibt an Stelle 37. 


Die Zeichen zur Cursorsteuerung sind in gewissem Sinne auch 
'Aruckbar'. Hierauf wie auf weitere Möglichkeiten der Cursor- 
steuerung in Commodore-BASIC gehen wir in Abschnitt 3.9 ein. 


3.4.2 Ausgabezeile mit PRINT 


Programm DEMO-PRINTI demonstriert die Wirkung der Trennungs- 
zeichen "," und ";" sowie der Funktionen TAB (Tabulator) und 
SPC (Space, Leerschritt) auf die am Bildschirm gerade ausgege- 
bene Zeile. 


DEMONSTRATION ZUR AUSGABEFORMATIERUNG MIT PRINT. 
ZAHL EINTIPPEN: 196.25 
TEXT EINTIPPEN: BETRAG 


1234567890123456789012345678901 234567890 
BETRAG 196 .25 
BETRAG 196.25 
BETRAG 196.25 
BETRAG 196.25 

BETRAG 196.25 

BETRAG 196.25 
1234567890123456789012345678901234567890 
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Das 
während das 
sition 1, 
Die Zahl 196.25 wird in Zeile 160 
geben, 


v.n 
N 


bewirkt eine Ausgabe auf der nächsten Zeilenposition, 
"," eine 10-spaltige Ausgabe vornimmt und zur Po- 
21 bzw. 31 vorrückt.. 

'erst' 


11, 
in Position 12 ausge- 


da in Position 11 die Vorzeichenstelle steht (unsicht- 


bar, da positiv). 


Ausführung zu Programm DEMO-PRINTI: 


100 
110 
120 
130 
140 
150 
160 
170 
180 
190 
200 
210 
220 
230 


PRINT 
PRINT 
INPUT 
INPUT 
PRINT 
PRINT 
PRINT 
PRINT 
PRINT 
PRINT 
PRINT 
PRINT 
END 


======PROGRAMM DEMO-PRINTI 


CHR$ (147); 

"DEMONSTRATION ZUR AUSGABEFORMATIERUNG MIT PRINT." 
"ZAHL EINTIPPEN: ";R 

"TEXT EINTIPPEN: ";R$ 

"12345678901 23456789012345678901234567890" 
R$,R 
R$,,R 
R$;R 
R$;" HR 

TAB( 5);R$; TAB( 20);R 

SPC( 5);R$; SPC( 20);R 
"1234567890123456789012345678901234567890" 


Eine Ausgabeformatierung mit Anweisungen 
des Typs PRINT USING sieht das BASIC 2.0 standardmäßig nicht 
vor. 

Mit SIMON's BASIC hingegen ist eine formgerechte Ausgabe 
lich (vgl. USE-Anweisung in Abschnitt 3.10.5). 


mög- 


3.4.3 Verwendung des Füllstrings 


Mit einem Füllstring können wir die Druckzeile 
bzw. Blancs auf eine gewünschte Länge bringen. 
rung zu Programm FUELLSTRINGI hat die Zeile 25 
wird ein Füllstring B$ 
baut, der mit T1$ und T2$ auf 25 Stellen Länge 


Programmzeile 160 


Codierung zu FUELLSTRINGI: 


mit Leerstellen 
Bei der Ausfüh- 
zeichen. In der 
Länge R aufge- 
verkettet wird. 


mit 


Ausführung zu FUELLSTRINGI: 


100 REM ======PROGRAMM FUELLSTRINGI1 TEXT RECHTSBUENDIG MITTELS 
110 PRINT "TEXT RECHTSBUENDIG MITTELS" FUELLSTRING FORMATIEREN. 
120 PRINT "FUELLSTRING FORMATIEREN." 1. TEXTZEILE: COMMODORE 64 
130 INPUT "1. TEXTZEILE: ";T1$ 2. TEXTZEILE: STETS NEU 
140 INPUT "2. TEXTZEILE: ";T2$ STELLE BEGRENZUNG RECHTS: 25 
150 INPUT "STELLE BEGRENZUNG RECHTS: ";R COMMODORE 64 
160 FOR I = 1 TOR: LETB$ = B$ + " ": NEXTI STETS NEU 
170 LET T1$ = RIGHT$ (B$ + T1$,R) ENDE. 

180 LET T2$ = RIGHT$ (B$ + T2$,R) 

190 PRINT T1$: PRINT T2$ 

200 PRINT "ENDE.": END 
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3.4.4 Ausgabe runden 


Der Kaufmann fordert eine gerundete und formatierte Zahlenaus- 
gabe. Das Runden einer Zahl Z auf S Dezimalstellen genau kann 
in einer Anweisung als 100 LET Z = (2*10%45+0.5)/(10%s) 
geschrieben werden (10?7S für '10 hoch S'). Daraus erhalten wir 
für das Runden auf 2 Stellen 100 LET Z = (2*100+0.5)/100. Das 
Programm RUNENZAHLI löst den Rundungsablauf in vier Schritte 
auf und gibt sie zur Veranschaulichung aus. 


Codierung zu RUNDENZAHLI: Ausführung zu RUNDENZAHL1: 
100 REM ======PROGRAMM RUNDENZAHLI RUNDEN. 
110 PRINT "EINE ZAHL ZUR DRUCKAUSGABE RUNDEN." EINE ZAHL ZUR DRUCKAUSGABE 
120 INPUT "ZU RUNDENDE ZAHL: ";Z ZU RUNDENDE ZAHL: 23.745 
130 INPUT "KOMMASTELLEN: ".S KOMMASTELLEN: 2 

140 LETZ = Z* 10 t S: PRINT Z 2374.5 

150 LETZ= Z + 0.5: PRINT Z 2375 

160 LET Z = INT (Z): PRINT Z 2375 

170 LETZ=Z/ (10 ? S): PRINT Z 23.75 

180 PRINT "ENDE.": END ENDE. 


Das Programm KOMMERZZAHL1I stellt Zahlen als Übersicht formge- 
recht untereinander, ergänzt fehlende Dezimalstellen, ersetzt 
Dezimalpunkte durch Kommata und setzt 1000er-Punkte. 

zur Umformung wird die Zahl Z in einen String Z$ umgewandelt. 


Codierung zu Programm KOMMERZZAHLI: 


100 REM ======PROGRAMM KOMMERZZAHL1 

110 PRINT "EINE ZAHL BIS ZU 7 VORKOMMASTELLEN" 

120 PRINT "ZUR KOMMERZIELLEN AUSGABE AUFBEREITEN." 

130 : 

140 INPUT "BELIEBIGE ZAHL: ";Z: LET Z$ = STR$ (Z): LETN = LEN (Z$) 

150 IF LEN ( STR$ ( INT (Z))) > 8 THEN PRINT "MAXIMAL 7 VORKOMMASTELLEN": 
160 REM sek NACHKOMMA-NULLEN ANFUEGEN 3Rkkkakakakaksisioiciksieisiniksiolaksieiokieiieksickikekikck 
170 IF MID$ (Z$,N - 1,1) = "." THEN LET Z$ = Z$ + "0": GOTO 200| GOTO 140 
180 IF MID$ (Z$,N - 2,1) < > "." THEN LET Z$ = Z$ + ".00" 

190 REM **%* AUF LAENGE 7+3=10 BRINGEN Krkkkkaakakakskslslsislslslloiiioksiokskekskikick 
200 LET Z$ = RIGHT$ (" " + Z$,10) 

210 REM *%** DEZIMALPUNKT DURCH KOMMA ERSETZEN Free ERROR 
220 LET Z$ = LEFT$ (Z$,7) + "," + RIGHT$ (Z$,2) 

230 REM  *kk TAUSENDER-PUNKTE SETZEN k3kakskakakskstststsigigigiksieieieksieksksinkiinkakikikikikick 
240 IFZ > = 1000 THEN LET Z$ = LEFT$ (Z$,4) + "." + RIGHT$ (Z$,6) 

250 IF Z > = 1000000 THEN LET Z$ = LEFT$ (Z$,1) + "." + RIGHT$ (Z$,10) 
260 PRINT "ZAHL AUFBEREITET: ";Z$ 

270 END 


Ausführungen zu Programm KOMMERZZAHLI!: 


EINE ZAHL BIS ZU 7 VORKOMMASTELLEN EINE ZAHL BIS ZU 7 VORKOMMASTELLEN 
ZUR KOMMERZIELLEN AUSGABE AUFBEREITEN. ZUR KOMMERZIELLEN AUSGABE AUFBEREITEN. 
BELIEBIGE ZAHL: 100238.4 BELIEBIGE ZAHL: 6125005 

ZAHL AUFBEREITET: 100.238,40 ZAHL AUFBEREITET: 6.125.005,00 
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3.4.5 Druckausgabe 
3.4.5.1 Gesamte Ausgabe auf den Drucker leiten 


Die CMD-Anweisung leitet alle Ausgaben des Commodore 64 vom 
Bildschirm zum Drucker um. 
Geben wir im direkten Dialog ein 

OPEN 1,4 J/RET/ Kanal 1 zum Gerät 4 (Drucker) Öffnen 

CMD 1 /RET/ Alle Daten über Kanal 1 zum Drucker, 
so werden alle nachfolgend auszugebenden Daten auf dem Drucker 
erscheinen. 
Mit der Befehlsfolge 

OPEN 1,4: CMD 1: /RET/ 

LIST /RET/ 

RUN /RET/ 

PRINT#1 /RET/ 

CLOSE 1 
wird das gerade im RAM befindliche Programm auf dem Drucker 
gelistet. Anschließend wird auch die Ausführung ausgedruckt. 
Vor dem Schließen von Kanal 1 (bzw. logischer Datei 1) muß zu- 
mindest ein PRINT#1 gesendet werden. 
Für die Informationsverbindung zwischen Commodore 64 und Druk- 
ker haben wir die Kanalnummer 1 gewählt. Ebenso können wir ei- 
ne andere Nummer 1,2,...,14 wählen. cCMD kann auch innerhalb 
eines Programms stehen. So gibt z.B. das Programm 

100 OPEN 2,4 : CMD 2 

110 PRINT "DRUCK" 

120 PRINT #2 : CLOSE 2 
bei RUN das eine Wort DRUCK auf dem Drucker aus. 


3.4.5.2 Einzelne Zeilen ausdrucken 


Die Anweisung CMD übergibt alle Daten an den Drucker, die An- 
weisung PRINT# hingegen jeweils nur eine Ausgabezeile. 
Das Programm 

100 OPEN 1,4 

110 PRINT#1 "COMMODORE 64" 

120 PRINT#1 

130 PRINT#1,"HAT 64K RAM" 

140 CLOSE 1 

150 END 
gibt zwei Druckzeilen getrennt von einer Leerzeile aus. Die 
PRINT#1-Anweisung sendet die Ausgabe über den Kanal 1, der zu- 
vor als Informationsverbindung zum Drucker (=Gerätenummer 4) 
eröffnet wurde. 


Ersetzen wir die Anweisung 100 OPEN 1,4 durch 100 OPEN 1,3, 
dann wird die Ausgabe auf dem Bildschirm (=Gerätenummer 3) er- 
scheinen. 

Auf diese Art können wir Programme, die Druckausgaben aufwei- 
sen, ohne Einsatz des Druckers am Bildschirm testen. 
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3.5 Maschinennahe Programmierung 


Arbeiten wir mit der Programmiersprache BASIC „ dann bewegen 
wir uns auf einer 'mittleren' Sprachebene zwischen unserer Um- 
gangssprache einerseits und der 011011001...-Sprache des Conm- 
puters andererseits, also der Maschinensprache. 

Wenden wir uns einer Programmiersprache wie PASCAL zu, So ent- 
fernen wir uns noch mehr vom Computerkern: PASCAL ist stärker 
strukturiert und hat komplexere Sprachelemente als BASIC. Wen- 
den wir uns umgekehrt der Maschinensprache (Assembler) zu, So 
befinden wir uns auf der "untersten' Sprachebene des PCs, d.h. 
auf der Ebene seiner aus Bitmustern wie 01101011 bestehenden 
'Muttersprache' 

In diesem Abschnitt wollen wir einen kleinen Schritt in Rich- 
tung auf die "unterste' Sprachebene wagen: wir betrachten die 
Zeichendarstellung und -codierung, die bitweise Verarbeitung, 
den unmittelbaren Zugriff auf Speicherplatzinhalte und den Um- 
gang mit Maschinenprogrammen. 


3.5.1 Zeichendarstellung im ASCII 


Alle Zeichen - seien es Ziffern, Buchstaben oder auch Sonder- 
zeichen - werden im ASCII dargestellt, d.h. es wird z.B. nicht 
der Buchstabe A gespeichert, sondern dessen ASCII-Codezahl 65. 
Die Funktion CHR$ haben wir bereits in Abschnitt 3.3 (Textver- 
arbeitung) verwendet; sie gibt uns für eine Codezahl zwischen 
0 - 255 das zugehörige ASCII-Zeichen an. Programm CHR$-TESTI 
ermöglicht uns, diese Funktion zu testen. 


ER ST a Te u Be vr Rn a ye 


# von 0-31 Steuerzeichen, 

16 z.B. für CHR$(19) /CLR- HOME'/ 

32 ER N ( ) a la Sl er"; 
#B- 1%, Musa, SEA TEE BB re Mrd 
SEE Te RT N ES ST ee 2 Ben ee A Be A PR u ee 
ERBE, BIER IS PT IET UT WM Baar on A ih - 
96 ab 96: Grafik-Zeichen 
112 


Bsp: Codezahl 64+1=65 für A; Codezahl 48+13=61 für = 
ASCII-Zeichenvorrat von 0 bis 127 


Codierung und zwei Ausführungen zu Programm CHR$-TESTI: 


100 REM ======PROGRAMM CHR$-TESTI 

110 PRINT "TEST DER FUNKTION CHR$( )." 

120 PRINT "A,E TIPPEN FUER CHR$(A,..,E):" 
130 INPUT A,E 

140 FOR I = A TO E: PRINT CHR$ (I);: NEXT I 
150 END 
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TEST DER FUNKTION CHR$( ). 
A,E TIPPEN FUER CHR$(A,..,E): 
232,95 
I#$SR&E'C)*+,-./0123456789: ;<=>?@ABCDEFGHIJKLMNOPORSTUVWXYZL\]T_ 


TEsT DER FUNKTION CHR&C>. 
A.E TIPPEN FUER CHREIA....E>: 128,255 
ia Te AT DT IT 


Funktion ASC liefert als Umkehrung der Funktion CHR$ die ent- 
sprechende Codezahl. Das Zeichen ! wird als Codezahl 33 und 
das Zeichen 0 als Codezahl 48 intern gespeichert. Das ! kommt 
vor der 0, es gilt !<0O . Die Wertigkeiten der Codezahlen be- 
stimmen demnach die Sortierfolge; wir werden bei den Sortier- 
verfahren in Abschnitt 3.7 darauf zurückkommen. 

Das Programm ASCII-TESTI dient dem Testen der Funktion ASC. 


Codierung zu Programm ASCII-TESTI: 


100 REM ======PROGRAMM ASCII-TESTI 

110 PRINT "ASCII-WERTE VON ZEICHEN TESTEN (O=ENDE):" 
120 INPUT "EINGABE EINES ZEICHENS NORMAL <- ";2$ 

130 PRINT "DARSTELLUNG IM ASCII INTERN -> "; ASC (Z$) 
140 IF ASC (Z$) < > 48 THEN 120 

150 PRINT "TESTENDE.": END 


Ausführung zu Programm ASCII-TESTI: 


ASCII-WERTE VON ZEICHEN TESTEN (O=ENDE): 
EINGABE EINES ZEICHENS NORMAL <- ! 
DARSTELLUNG IM ASCII INTERN -> 33 
EINGABE EINES ZEICHENS NORMAL <- 1 
DARSTELLUNG IM ASCII INTERN -> 49 
EINGABE EINES ZEICHENS NORMAL <- # 
DARSTELLUNG IM ASCII INTERN -> 35 
EINGABE EINES ZEICHENS NORMAL <- O 
DARSTELLUNG IM ASCII INTERN -> 48 
TESTENDE. 


3.5.2 Umwandlung dezimal, binär und hexadezimal 


Programm DEZIMALBINAER1 wandelt eine Dezimalzahl D in eine Bi- 
närzahl B um, die als 16-Elemente-Array vereinbart ist (Anwei- 
sung 140 DIM B(16) reserviert für B genau 16 Zahlkomponenten). 
Zur Umwandlung in der Schleife 160 FOR I ... 190 NEXT I wird 
D wiederholt halbiert, um bei Teilbarkeit ohne Rest eine 0 und 
sonst eine 1 nach B zu schreiben. Diese Binärzeichen 0 bzw. 1 
schreibt DEZIMALBINAERI1 in Richtung der höheren Wertigkeit von 
rechts nach links nach B; deshalb auch die Schrittweite STEP-I 
in der FOR-Anweisung (Stelle 16, 15, 14, ...). 
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Ausführungen zu Programm DEZIMALBINAERI: 


UMWANDLUNG DEZIMAL --> BINAER 
(BINAERMUSTER ALS ARRAY BZW. FELD). 
DEZIMALZAHL EINGEBEN: 51 


UMWANDLUNG BINAER: 
0000000000110011 


UMWANDLUNG DEZIMAL --> BINAER 
(BINAERMUSTER ALS ARRAY BZW. FELD). 
DEZIMALZAHL EINGEBEN: 65535 


UMWANDLUNG BINAER: 
I11l1111111111111 


Codierung zu Programm DEZIMALBINAERI: 


100 REM ======PROGRAMM DEZIMALBINAER1 

110 PRINT "UMWANDLUNG DEZIMAL --> BINAER" 

120 PRINT "(BINAERMUSTER ALS ARRAY BZW. FELD)." 

130 : 

140 DIM B(16): INPUT "DEZIMALZAHL EINGEBEN: ";D 

150 IFD< > INT (D) THEN PRINT "GANZZAHLIG.": GOTO 140 
160 IF D > 65536 THEN PRINT "KLEINERE ZAHL.": GOTO 140 
170 FOR I = 16 TO 1 STEP -1 

180 IFD/ 2= INT (D / 2) THEN B(I) = O 

190 IFD/ 2< > INT (D/ 2) THEN B(I) = 1 

200 LETD= INT (D / 2) 


210 NEXT I 

220 PRINT : PRINT '"UMWANDLUNG BINAER:" 

230 FOR I = 1 TO 16: PRINT B(I);" ";: NEXTI 
240 . END 


Programm BINAERDEZIMAL1 unterscheidet sich in zwei Punkten vom 
Programm DEZIMALBINAER1: Einserseits wird umgekehrt umgewan- 
delt (binär - dezimal), und andererseits liegt das Binärmuster 
als String B$ vor, nicht aber als Array B( ). Mit MID$(B$,I,1) 
nimmt man das jeweils nächste Zeichen von B$; da es stets eine 
0 oder 1 ist, kann dieses Zeichen mit VAL in einen numerischen 
Wert verwandelt und nach S zugewiesen werden (S für Stellenin- 
halt). Dann wird 'S mal (2 hoch (L-I))' multipliziert und der 
so errechnete Stellenwert in Zeile 170 zur Dezimalzahl D hin- 
zuaddiert. 


Codierung und Ausführungen zu Programm BINAERDEZIMALI1: 


UMWANDLUNG BINAER --> DEZIMAL UMWANDLUNG BINAER --> DEZIMAL 
(BINAERMUSTER ALS STRING). (BINAERMUSTER ALS STRING). 
BINAERMUSTER TIPPEN: BINAERMUSTER TIPPEN: 
?1111111111111111 ?110011 

UMWANDLUNG DEZIMAL: 65535 UMWANDLUNG DEZIMAL: 51 


ENDE. ENDE. 
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100 REM ======PROGRAMM BINAERDEZIMALI 
110 PRINT "UMWANDLUNG BINAER --> DEZIMAL" 
120 PRINT "(BINAERMUSTER ALS STRING) ." 
130 PRINT "BINAERMUSTER TIPPEN:": INPUT B$ 


140 LET D= 0: LETL= LEN (B$) 

150 FOR I=1T0L 

160 LET S= VAL ( MID$ (B$,1,1)) 
170 LETD=D+S*(2t(L-1I)) 
180 NEXT I 


190 PRINT "UMWANDLUNG DEZIMAL: ";D 
200 PRINT "ENDE.": END | 


Hexadezimalziffern sind 0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F. Diese 
16 Ziffern werden auch kurz Hex-Ziffern oder Sedezimal-Ziffern 
genannt (vgl. Abschnitt 1.2.3.2).. 

Programm HEXDEZIMALI demonstriert den Umwandlungsvorgang von 
hex nach dez. In Teil 1 des Programms prüfen wir, ob die Ein- 
gabe H1$ nur aus den 16 Hex-Zeichen 0123456789ABCDEF besteht. 
In Teil 2 geschieht die Umwandlung: Die Hex-Zeichen A-F werden 
durch die Dez-Zeichen 10-15 ersetzt und in Z abgelegt. Darauf- 
hin wird Z mit den jeweiligen Stellenwerten 1 (=16 hoch 0), 16 
(=16 hoch 1), 256 (=16 hoch 2), ... multipliziert und zur De- 
zimalzahl D hinzuaddiert. 


Ausführungen zu Programm HEXDEZIMAL1: UMWANDLUNG HEX --> DEZIMAL. 
WERT HEX TIPPEN: FFFF 
UMWANDLUNG HEX --> DEZIMAL. 


WERT HEX TIPPEN: 6D PRUEFUNG AUF GUELTIGKEIT: 
1. ZEICHEN IN FFFF KORREKT. 
PRUEFUNG AUF GUELTIGKEIT: 2. ZEICHEN IN FFFF KORREKT. 
l. ZEICHEN IN 6D KORREKT. 3. ZEICHEN IN FFFF KORREKT. 
2. ZEICHEN IN 6D KORREKT. 4. ZEICHEN IN FFFF KORREKT. 
UMWANDLUNG: UMWANDLUNG: 
FUER D: O UM 13 ERHOEHT. FUER F: O UM 15 ERHOEHT. 
FUER 6: 13 UM 96 ERHOEHT. FUER F: 15 UM 240 ERHOEHT. 
FUER F: 255 UM 3840 ERHOEHT. 
ERGEBNIS: FUER F: 4095 UM 61440 ERHOEHT. 


6D HEX ERGIBT 109 DEZIMAL. 
ERGEBNIS: 
FFFF HEX ERGIBT 65535 DEZIMAL. 


Codierung zu Programm HEXDEZIMALI: 


100 REM ======PROGRAMM HEXDEZIMAL] 

110 PRINT "UMWANDLUNG HEX --> DEZIMAL." 
120 : 

130 REM ======VEREINBARUNGSTEIL 


140 REM HO$: TEXT (16 HEX-ZEICHEN) 
150 REM H1$: TEXT (UMZUWANDELNDER EINGABETEXT) 


160 REM L: INTEGER (LAENGE VON H1$) 

170 REM F: INTEGER (FLAGGE FUER EINGABEFEHLER) 
180 REM D: INTEGER (ERGEBNIS IM DEZIMALSYSTEM) 
190 REM Z TEXT (NAECHSTES ZEICHEN VON H1$) 


200 REM L, J: INTEGER (LAUFVARIABLEN) 
210 : 
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220 REM ======ANWEISUNGSTEIL 

230 LET HO$ = '0123456789ABCDEF": REM 16 HEX-ZEICHEN 

240 INPUT "WERT HEX TIPPEN: ";Hl$: PRINT 

250 LETL= LEN (HI$) 

260 REM ***TEIL 1: EINGABE AUF GUELTIGKEIT PRUEFEN*** tk 
270 PRINT "PRUEFUNG AUF GUELTIGKEIT:" 


280 FOR I = 1 TOL 
290 LET F = 1: REM FLAGGE F AUF 1=FEHLER SETZEN 
300 FOR J = 1 TO 16 


310 IF MID$ (HO$,J,1) = MID$ (H1$,I,1) THEN LETF= O0 
320 NEXT J 

330 IF F= 1 THEN 540 

340 PRINT 1;'". ZEICHEN IN ";H1$;" KORREKT." 

350 NEXT I 

360 REM *%**TEIL 2: UMWANDLUNG HEX --> DEZIMALFFRFIRTRRTRK 
370 PRINT : PRINT "UMWANDLUNG:" 

380 FOR I = 1 TOL 

390 LET Z$ = MID$ (HI$,(L - I + 1),1) 


400 IFZ$< = "9" THEN LET Z = VAL (Z$) 
410 IF Z$ = "A" THEN Z = 10 

420 IF Z$ = "B" THEN Z = 11 

430 IF Z$ = "C" THEN Z = 12 

440 IF Z$ = "D" THEN Z = 13 

450 IF Z$ = "E" THEN Z = 14 

460 IF Z$ = "F" THEN Z = 15 

470 LETZ=Z* (16 f (I - 1)) 

480 PRINT "FUER ";2$;": "sD;" UM ";Z;" ERHOEHT." 
490 LETD=D+Z 

500 NEXT I 


510 PRINT : PRINT "ERGEBNIS:" 

520 PRINT H1$;'" HEX ERGIBT '";D;'" DEZIMAL.": GOTO 550 
530 GOTO 550 

540 PRINT 1;",. ZEICHEN IN ";H1$;'" FEHLERHAFT." 

550 END 


Programm DEZIMALHEX1 wandelt umgekehrt Dezimalzahlen in Hexa- 
dezimalzahlen um und läuft entsprechend dem "Vorgehen 2' der 
Abbildung ab. 

Zur Bestimmung der Hexadezimalziffer HZI$ gehen wir dabei wie 
folgt vor: Hat HZI einen Wert 0,1,2,...,9, so erhalten wir mit 
CHR$(48+HZ2I) die entspr. Ziffer 0,1,2,...9. Hat HZI aber einen 
Wert zwischen 10 und 15, ermittelt CHR$(55+HZI) die zugehörige 
ziffer A,B,..,F. Beispiele: CHR$(55+11) ergibt CHR$(66) ergibt 
B; CHR$(48+4) ergibt CHR$(52) ergibt 4. Dabei wird berücksich- 
tigt, daß die Dezimalziffern im ASCII mit Codezahl 48 beginnen 
und die Großbuchstaben mit Codezahl 65. Die Variable CODE ent- 
hält deshalb 48 oder aber 55 (55+10 für A ergibt dann 65). 


Ausführungen zu Programm DEZIMALHEX1: 


DEZIMALZAHL <- 23973 DEZIMALZAHL <- 266 
HEX-ZIFFER: 5 HEX-ZIFFER: A 
HEX-ZIFFER: A HEX-ZIFFER: O 
HEX-ZIFFER: D HEX-ZIFFER: 1 
HEX-ZIFFER: 5 HEXADEZIMALZAHL -> 10A 


HEXADEZIMALZAHL -> 5DA5 
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Zwei Vorgehensweisen zur Umwandlung von 23695 dez in 5C8F hex 


Codierung zu Programm DEZIMALHEXI: 


100 REM ======PROGRAMM DEZIMALHEX1 

110 REM ======VEREINBARUNGSTEIL 

120 REM DEZ: INTEGER (DEZIMALZAHL) 

130 REM HEX$: STRING (HEXADEZIMALZAHL) 

140 REM HZI: INTEGER (HEXADEZIMALZIFFER) 

150 REM HZI$: STRING (... FUER HZI) 

160 REM TEIL INTEGER (GANZZAHL-TEIL VON DEZ) 
170 REM CODE: INTEGER (ASCII-ZAHL FUER HZI) 


180 : 
190 REM ======ANWEISUNGSTEIL 
200 LET HEX$ = '"": REM LEERSTRING ZUM VERKETTEN MIT + 


210 INPUT "DEZIMALZAHL <- ";DEZ 

220 LET TEIL = INT (DEZ / 16) 

230 LET HZI = DEZ - (TEIL * 16) 

240 LET CODE = 48: IF HZI > 9 THEN LET CODE = 55 
250 LET HZI$ = CHR$ (CODE + HZI) 

260 PRINT '" HEX-ZIFFER: '";HZI$ 

270 LET HEX$ = HZI$ + HEX$ 

280 LET DEZ = TEIL: IF DEZ > O THEN 220 

290 PRINT "HEXADEZIMALZAHL -> ";HEX$: END 


3.5.3 Daten Bit für Bit verarbeiten 


Ergänzend zu DEZIMALBINAERI wollen wir zur "Umwandlung von 
Dezimalzahlen in Dualzahlen" die Programme DEZIMALBINAER2-4 
betrachten. 

Diese drei Programme demonstrieren den Einsatz des logischen 
Operators AND zur Verarbeitung einzelner Bits. 
Die logischen Operatoren haben wir bereits in Abschnitt 3.2.3 
im Zusammenhang mit der Verzweigungstechnik (Programme BOOLEAN 
1-3) kennengelernt. 
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Im Ausführungsbeispiel zu Programm DEZIMALBINAER2 wird die 200 
in die Dualzahl 11001000 umgewandelt. Die Codierung zeigt, daß 
die Umwandlung in einer abweisenden Schleife über die Anwei- 
sungsfolge 

170 IF I=1 THEN 210 

180 LET I=I/2 

190 PRINT ABS( (IANDD) = I); 

200 GOTO 170 
mit den Zahlen D=200 und I=256 als Anfangswerten erfolgt. An- 
weisung 190 führt mit I AND D eine logische Operation über 
"logisch UND" durch. Dabei werden die INTEGER-Zahlen in I und 
D binär dargestellt und Bit für Bit mit AND (logisch UND) ver- 
knüpft. Für die Anfangswerte I=128 und D=200 wird demnach die 
Operation (I AND D) als (128 AND 200) computerintern binär als 
(10000000 AND 11001000) bitweise ausgeführt. Nur die 8. Stelle 
ergibt 1 als Stellenergebnis (1 AND 1 ergibt 1), während alle 
anderen Stellenergebnisse 0 ergeben. (10000000 AND 11001000) 
ergibt somit 10000000 bzw. 128 als Ergebnis. 
In Zeile 190 wird jetzt der Vergleich (128=128)? ausgeführt 
und als Ergebnis WAHR (TRUE bzw. -1) festgestellt. 
Dann wird in 190 der Absolutbetrag ABS(-1) gleich 1 ermittelt 
und mit PRINT 1; ausgegeben. 
Diese bitweise Manipulation mittels AND wiederholt sich bis 
I den Wert 1 erreicht hat. Die ersten drei Schleifendurchläufe 
werden in der Abbildung wiedergegeben. 


Anweisung 190 PRINT ABS((I AND D)=I); von Programm 
DEZIMALBINAER2 in Einzelschritten: 

Schleifendurchlauf: Bitweise Verknüpfung (I AND D): 
1. DURCHLAUF: I=128 und D=200. 10000000 =128 
(I AND D) ergibt I 1.1 2-0 :1720,9790 =200 
(I= I) ergibt -1I bzw. TRUE. --- --- - - - - - - - -- - - - --- - 
ABS(-1) ergibt 1. 10000000 =128 
2. DURCHLAUF: I=64 und D=200. 010200828200 = 64 
(I AND D) ergibt I. 1. EBD T RD =200 
(I = I) ergibt -1I bzw. TRUE. ---- -- -- - - -- - - - - - - - - - - - - 
ABS(-1) ergibt 1. 0 1 000 80 °0.0 = 64 
3.- DURCHLAUF: I=32 und D=200, 00100000 = 32 
(I AND D) ergibt 0. Le DH =200 
(0 AND I) ergibt 0 bzw. FALSE. --------------- I ---------- 
ABS(0) ergibt 0, 9:08 DD 070: O = OO 


Beispiel zur bitweisen Verknüpfung mittels AND 


Ausführung zu Programm DEZIMALBINAER2: 


UMWANDLUNG EINER DEZIMALZAHL IN EINE DUALZAHL 
(METHODE: VERGLEICHEN MIT LOGISCH 'UND'. 
ERGEBNIS: BINAERMUSTER AUS 8 EINZELZAHLEN). 
GANZZAHL UNTER 256? 200 
200 ALS 8-STELLIGE DUALZAHL: 
1100710000 
ENDE. 
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Codierung zu Programm DEZIMALBINAER2: 


100 REM ======PROGRAMM DEZIMALBINAER2 

110 PRINT "UMWANDLUNG EINER DEZIMALZAHL IN EINE DUALZAHL" 
120 PRINT '"(METHODE: VERGLEICHEN MIT LOGISCH 'UND'." 
130 PRINT "ERGEBNIS: BINAERMUSTER AUS 8 EINZELZAHLEN)." 
131 : 

140 INPUT "GANZZAHL UNTER 256"; D 

150 LET I=256 

160 PRINT D;" ALS 8-STELLIGE DUALZAHL:;" 

170 IF I=1 THEN 210 

180 LET I=1/2 

190 PRINT ABS( (I ANDD) = I); 

200 GOTO 170 

210 PRINT: PRINT "ENDE.": END 


I als Filter bzw. als Maske: 

Die logische Operation (I AND D) wird in einer Schleife wie- 
derholt ausgeführt. Dabei bleibt D=200 konstant, während I die 
8 Werte 128=10000000, 64=01000000, 32=00100000, 16=00010000, 
8=00001000, 4=00000100, 2=00000010 und 00000001 annimmt. 

I wirkt wie ein Fi 1 t er , der mittels UND bei jedem neuen 
Schleifendurchlauf eine ggf. vorhandene "1" in einer anderen 
Bitposition herausfiltert: in Position 8, 7, 6, ..., 1. 

Ebenso kann man I als Maske auffassen, die über eine zu 
prüfende Variable (hier über D) gelegt wird. 


Die Programme DEZIMALBINAER3 und DEZIMALBINAER2 bezwecken das- 
selbe, nur wird jetzt die AND-Operation als 

170 PRINT SGN(D AND (2 hoch I)); 
geschrieben. Als Filter bzw. Maske dient wieder 128 (2 hoch 
7 ergibt 128), 64 (2 hoch 6 ergibt 64), ... 


Codierung und Ausführung zu Programm DEZIMALBINAER3: 


100 REM ======PROGRAMM DEZIMALBINAER3 

110 PRINT "UMWANDLUNG EINER DEZIMALZAHL IN EINE DUALZAHL" 
120 PRINT "(METHODE: EXPONENT SOWIE LOGISCH 'UND'." 

130 PRINT "ERGEBNIS: BINAERMUSTER AUS 8 EINZELZAHLEN)." 
131 : 

140 INPUT "GANZZAHL UNTER 256"; D 

150 PRINT '"8-STELLIGE DUALZAHL:" 

160 FOR I=7 TO O STEP -1 

170 PRINT SGN(D AND 2°I); 

180 NEXT I 

190 PRINT: PRINT "ENDE." : END 

Ok 


UMWANDLUNG EINER DEZIMALZAHL IN EINE DUALZAHL 
(METHODE: EXPONENT SOWIE LOGISCH 'UND'. 
ERGEBNIS: BINAERMUSTER AUS 8 EINZELZAHLEN). 
GANZZAHL UNTER 256? 200 

8-STELLIGE DUALZAHL: 

11001000 

ENDE. 
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DEZIMALBINAER2 sowie DEZIMALBINAER3 wandeln nur Dezimalzahlen 
bis max. 256 in Binärzahlen umwandeln. Programm DEZIMALBINAER4 
hebt die Begrenzung bis 256 (=2 hoch 8) auf und wandelt Zahlen 
bis maximal 65536 (=2 hoch 16) um. 

Dazu wird der Zahlenwert in ein BYTELINKS und ein BYTERECHTS 
aufgeteilt. 


Auf Zwei-Byte-Adressen mit einem niederwertigen Byte (hier als 
BYTELINKS benannt) und einem höherwertigen Byte (BYTERECHTS) 
gehen wir in Abschnitt 3.5.5.1 ausführlich ein). 


Codierung und Ausführungen zu Programm DEZIMALBINAER4: 


100 REM ======PROGRAMM DEZIMALBINAER4 

110 PRINT "UMWANDLUNG EINER DEZIMALZAHL IN EINE DUALZAHL" 
120 PRINT '"(METHODE: EXPONENT SOWIE LOGISCH 'UND'; ZERLEGEN." 
130 PRINT "ERGEBNIS: BINAERMUSTER AUS 16 EINZELZAHLEN)." 
131 : 

140 INPUT "GANZZAHL UNTER 65536"; ZAHL : PRINT 

150 BYTELINKS = INT (ZAHL/256) 

160 PRINT "HOEHERWERTIGES LINKES BYTE'"; BYTELINKS 

170 PRINT "ALS DUALZAHL: "; 

180 LET D=BYTELINKS : GOSUB 1000 

190 LET BYTERECHTS = ZAHL - BYTELINKS*256 : PRINT 


191 : 

200 PRINT "NIEDERWERTIGES RECHTES BYTE"; BYTERECHTS 
210 PRINT "ALS DUALZAHL: "; 

220 LET D=BYTERECHTS : GOSUB 1000 

230 END 


240 : 

1000 FOR I=7 TO O0 STEP -1 
1010 PRINT SGN(D AND 21I); 
1020 NEXT I 

1030 RETURN 


RUN 

UMWANDLUNG EINER DEZIMALZAHL IN EINE DUALZAHL 
(METHODE: EXPONENT SOWIE LOGISCH 'UND'; ZERLEGEN. 
ERGEBNIS: BINAERMUSTER AUS 16 EINZELZAHLEN). 
GANZZAHL UNTER 65536? 32267 


HOEHERWERTIGES LINKES BYTE 126 
ALS DUALZAHLE O1 1 117110 
NIEDERWERTIGES RECHTES BYTE 11 
ALS DUALZAHLLE OO OO ı 0 11 


RUN 

UMWANDLUNG EINER DEZIMALZAHL IN EINE DUALZAHL 
(METHODE: EXPONENT SOWIE LOGISCH 'UND'; ZERLEGEN. 
ERGEBNIS: BINAERMUSTER AUS 16 EINZELZAHLEN). 
GANZZAHL UNTER 65536? 65000 


HOEHERWERTIGES LINKES BYTE 253 
ALS DUALZAHLCE: I 1111717107] 
NIEDERWERTIGES RECHTES BYTE 232 
ALS DUALZAHLE 11101000 
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3.5.4 Unmittelbarer Zugriff auf Speicherinhalte 
3.5.4.1 Stufe 1: Freien Speicherplatz überprüfen 


Der wiedergegebene direkte Dialog gibt ein Beispiel, wie durch 
Anwendung der Funktion FRE(0) der noch freie Speicherplatz ab- 
gefragt werden kann. 

Zunächst löschen wir den Hauptspeicher RAM mittels NEW. 

Vor dem Laden des Programms VERBRAUCHI sind noch 38908 Bytes 
frei, das sind die 38911 Bytes RAM nach dem Systemstart abzüg- 
lich 3 Bytes für die Direktanweisung PRINT FRE(0). Nach Laden 
von VERBRAUCH]1 verbleiben noch 38791 Bytes und nach Ausführung 
noch 38770 Bytes. 

Die Anweisungen des Programms VERBRAUCHI beanspruchen demnach 
117 Bytes an Speicherplatz (38908-38791). 

während der Ausführung werden Zahlenwerte in die Variablen T 
(60), K (346) und D (17.3410405) zugewiesen. Dafür belegt der 
Computer genau 21 Bytes an Speicherplatz (38791-38770). 

In Abschnitt 3.5.5 gehen wir auf die Speicherung der Daten und 
Anweisungen eines BASIC-Programms näher ein. 


Direkter Dialog zur Demonstration der Funktion FRE(D): 


NEW /RET/ RUN /RET/ 

READY. EINGABE: GEFAHRENE KM 

PRINT FRE(0) /RET/ 346 /RET/ 

-26627 AUSGABE: LITER/100 KM 

READY. 17.3410405 

PRINT FRE(0)+65535 /RET/ 

38908 PRINT FRE(0)+65535 /RET/ 
38770 

LOAD "VERBRAUCH1",8 READY. 

SEARCHING FOR VERBRAUCHI 

LOADING 

READY. /RET/ bedeutet "RETURN-Taste 
drücken. 

PRINT FRE(0)+65535 /RET/ Programm VERBRAUCHI1: siehe 

38791 Abschnitte 2.2 sowie 3.1.1. 

READY. 


Warum antwortet die Funktion FRE(0) mit negativen Zahlen? 
FRE(0) wird als Ganzzahl (INTEGER-Zahl) gespeichert. Da Daten 
des Typs "Ganzzahl" nur Zahlen bis maximal 32767 sein können, 
werden bei größeren Zahlen negative Zahlen angezeigt. Addieren 
wir 65535 hinzu, erhalten wir den 'richtigen' Wert. 


3.5.4.2 Stufe 2: Speicherplatzinhalte mit PEEK lesen 


PEEK(30000) gibt den Inhalt des Speicherplatzes mit der Adres- 
se 30000 wieder - mit PRINT PEEK(30000) als Direktanweisung 
oder aber mit 

20 PRINT "INHALT VON PLATZ 30000: ";PEEK(30000) 
als Programmanweisung. 
Die Anweisung 50 LET F=PEEK(30000) ordnet den Wert der Vari- 
ablen F zu und 70 IF PEEK(30000)=9 THEN.. fragt, ob in die- 
er Adresse der Zahlenwert 9 gespeichert ist. 
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Anmerkung: Negative Adressen legt das System als komplementäre 
zahlen zu 65536 als der größten durch ein Byte (8 Bits) dar- 
stellbare Zahl an. 


Die Zählerschleife 
FOR I=2048 TO 3071 : PRINT I;": ";PEEK(I); : NEXT I /RET/ 

gibt den Inhalt der Speicherplätze 2048 bis 3071 aus. Dieser 
dezimalen Adressenangabe entspricht die hexadezimale Angabe 
von 800 bis BFF, die zur Unterscheidung auch als %$%800 - $BFF 
geschrieben wird . Lassen wir die im direkten Dialog eingege- 
bene Schleife ablaufen, dann werden ASCII-Codezahlen zwischen 
0 und 255 gezeigt. Warum? 255 dezimal = $FF ist die größte 
in einem Byte bzw. einem Speicherplatz unterzubringende Zahl. 


Die Zählerschleife 

30 FOR Z=1 TO 7: LET A(Z)=PEEK(10767+2) : NEXT 2 
speichert die Inhalte der Speicherplätze 10768, 10769, ... in 
den Array A() ab. 


Arbeitet man mit PEEK (Adressinhalte direkt lesen) sowie POKE 
(direkt schreiben), so sind häufig Umrechnungen von hexadezi- 
malen in dezimale Adressangaben vorzunehmen. 
Diese Umrechnungen von HEX nach DEZ können mit der umseitigen 
Tabelle wie folgt vorgenommen werden: 
1. Beispiel: $FF69 - dezimal 65385 
FF (Zeile unten, Spalte rechts) ergibt 65280 als unteren 
Tabellenwert, da FF das 1. Ziffernpaar ist. 
69 (Zeile 6 und Spalte 9) ergibt 105 als oberen Wert, 
da 69 das 2. Paar ist. 
65280+105 ergibt dezimal 65385. 


2. Beispiel: $800 - dezimal 2048 
08 (obere Zeile 0 und Spalte 8) ergibt 2048 als unteren 
Tabellenwert, da 08 das 1. Paar ist. 
00 (obere Zeile und linke Spalte) ergibt 0. 
2048+0 ergibt dezimal 2048. 


Statusvariable ST als Beispiel für PEEK: 
Die Statusvariable ST ist in Adresse 144 abgelegt und enthält 
einen Wert ungleich null, wenn Ein-/Ausabefehler auftauchen. 
Der direkte Dialog 

LOAD "XxX",8 /RET/ 

FILE NOT FOUND ERROR 

READY. 

PRINT PEEK (144) /RET/ (Adresse 144 mit PEEK abfragen) 

66 

READY. 
zeigt, daß unter dieser Adresse 144 nach dem Versuch, das gar 
nicht existierende Programm XXX zu laden, der Wert 66 als Feh- 
lerart gespeichert worden ist. 
Gerade bei der Fehlerbehandlung sind derartige Abfragen über 
PEEK sehr nützlich. 
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I ıIı 1 Is ıaı 5 I6I 7 IB ST ATB I EI DL EI FI 
==22]==2=2=2===2]2=2=22== [2222222 ]===2223=2]2==22222 [2222222 ]22=222=]222==2=2 [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 ]22=2=2==] 
, I 11 21 31 41 31 bl 71 BI gs wı nı 121 13 14T 951 
08------ I I I I--- I I Im In I I I Ion Im I I ' 
, 01 231 SI21 7681 1024 I 1280 1 1536 I 1792 1 2048 I 2304 I 2560 I 2816 I 3072 I 3328 I 3584 I 3840 I 
=23]=222=22=]====2==2][===2====][===22=2== ]====2=2==]==22=222=2 [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 ]522=22=22 [2328222 [2222222 ]22===22] 
ı ki CI BI BI 2ı 1ı 2 ZI a1 SI 2 21 BI 21 301 318 

1 demmnnnn]onnnnn Immun [nn un Im] a ee Inn Inn [nn Immun Immmnnnn Im] 
8 409% I 4352 1 4608 I 4864 I 5120 I 5376 I 5632 I SBBB I 6144 I 6400 I 6656 I 6912 I 7188 I 7424 I 7680 I 7936 I 
==22]2=2=2===]=2=2=2==2=2=][==2=2=22= [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 [2222222] 
ı 21 SI MI SI SI vı 8 SS HH MI 21 SI MI SI MI 47] 
21---— I. Inn Immonun I Immun I en I I I I en Inn Im Immun 
8 8192 1 8448 I 8704 I 8960 I 9216 1 9472 1 9728 1 9984 1 10240 I 10496 1 10752 I 11008 I 11264 I 11520 1 11776 1 12032 I 
s22][=2=22=2=22=2 [2222222 ][=22=2=2=2==2][2=2==2=2==]222=2== [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 ]2======] 
ı 81 91 SI SI 23 SI MI SI SI yı SI SI 0 dl &21 631 
Jh [= Inn Inmmmnn Inn I-omnnnn [mann I. I------- Ion I [een I Inn Innen I] 
8 12288 I 12544 1 12800 I 13056 1 13312 1 13568 I 13824 I 14080 I 14336 I 14592 1 14848 I 15104 1 15360 I 15616 I 15872 I 16128 I 
==2]=222=22=2=2]222=2=22=]22=2=2=22=2]222=2=22=2 [2222222 [2222222 [2222222 ]23222==2 [2222222 ]=2=2==2222 [2222222 [2222222 [22=2===2]2=2=2=2=2= ]2=2==2==2]2=====2] 
ı di SI Il TI BI HI RI nı RI Bı WM SI RI TI RI 1 
II I I I-- I------ I In I-- Im I In Ion Immun Inn I] 
8 16384 I 16640 I 16896 I 17152 1 17408 I 17664 1 17920 I 18176 I 18432 I 18688 I 18944 I 19200 1 19456 1 19712 1 19968 I 20224 ] 
=22]=2==2=2==]==22=2222]2=2==222=2]==22=22==2 [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 ]2=222=22 [2222222 [2222222 [22222 == [2222222] 
ı DI il 21 SI Maı SI Sı TI RI BI wmı nı wi Sı MI 91 

5 I---.. I Io I--- I--- I-- I I I Im Deo I----- I I Im I 


8 20480 I 20736 1 20992 I 21248 I 21504 I 21760 I 22016 I 22272 I 22528 I 22784 1 23040 I 23296 I 23552 I 23808 I 24064 I 24320 I 


ı %] 971 1 91 1001 1011 1021 1031 1041 1051 1061 1071 1081 1091 101 A111 

6 1-1 [1 Im] 1 Im] Im] In Im Im Immo [ann] 
8 24576 I 24832 I 25088 I 25344 I 25600 I 25856 I 26112 I 26368 I 26624 I 26880 I 27136 1 27392 1 27648 I 27904 I 28160 I 28416 I 
s22]=2=2==2=2=2=2]=2=2=2====][22=2=2===2]2==2=2=2=2]2=2=222=2 [2222223] 2222222 [2222232 ]2222222 [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 [2222222] 
s 1121 131 14T MSI MR M7I BT ME 1208 Aa 12218 1231 1241 1251 1261 1271 

1 b--- I------- I------- I I I I I I I I I I I------- I I 
8 28672 1 28928 I 29184 1 29440 I 29696 I 29952 1 30208 I 30464 I 30720 I 30976 I 31232 I 31488 I 31744 1 32000 I 32256 I 32512. 1 
s22]=22=2=2=22]2222=2=2=]=2=2=2=2=2=2=2]2=22=2=== [2222222 [2222222 [2222222 [2222522 [22222522 [2222222 [2222222 [2222222 [2222222 [2222222 ]j2222ess]sseesee 
8 1281 1291 1301 A131 1321 1331 131 13518 1361 1710 ABI 199 10T MAI 1421 141 
BI Inn I. nn Immun I Inn Inn Inn Imnnnnn In I Immun I I In 
8 32768 1 33024 1 33280 1 33536 1 33792 1 34048 1 34304 I 34560 I 34816 I 35072 I 35328 I 35584 I 35840 I 36096 I 36552 I 36608 I 


8 11 1451 1461 17T NAT AMT ASOL ASEE 152I ASIE AST ASST AST STE ART 1590 
9 ---- I I----- I----- I I------ I I I------ I----- I------- Im I--- I I I 
8 36864 1 37120 1 37376 1 37632 1 37888 1 38144 1 38400 I 38656 1 38912 I 39168 1 39424 1 39680 1 39936 1 40192 I 40448 1 40704 1 


8 1601 1611 1621 1651 1641 1651 1661 1678 NAT 19 1701 Aa 17218 17358 17a 1751 
Ale II 1-1 I Im 14 nn I Immannnn [ann Immanunn I] 1 
8 40960 I 41216 1 41472 1 41728 I 41984 1 42240 1 42496 I 42752 1 43008 1 43264 I 43520 1 43776 1 44032 1 442B8 I 44544 I 44800 I 
==2]2=22=2==22 ]2=2===2 [2222222 [2=222==2= [2==2==2=22 [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 [2222282 [2222252 [22222] 
8 161 171 1788 179 1808 AB 1828 ABI 1 15 16T 187 ABEL 19T 10T AI 

B B----- [mm] [nn I-mmen [ann] I I 14 ERREIER UEAIBEE, DEEAEER Im ]nnnnnn [ann ' 
8 45056 1 45312 I 45568 I 45824 I 46080 1 46336 I 46592 I 46848 I 47104 1 47360 I 47616 1 47872 I 48128 1.485384 I 48640 I 48896 I 
a22]===2====2]2=2=2=2=2=]=2=2===2=2[====222=2 [2222222 [e22222= [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 [2202220 ae] 
8 1928 131 11 151 1%1 1971 198 191 2001 2011 2021 2051 2041 2051 2061 2071 
II Immun I-mmmnn [enn no I] I-mmmnnn [anna Jen Innen [anna Jenna 
8 49152 1 49408 I 49664 I 49920 1 50176 1 50432 I 50688 1 50944 1 51200 I 51456 1 51712 1 51968 I 52224 152480 I 52736 I 52992 I 
s2=]2======2]=2=2===2==]==2=22=22 [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 [2222228 [2222222 [2222220 Jessmaee]aeeeeee] seen] 
s 2081 20901 2101 211 221 2131 241 251 2161 271 2181 21918 201 241 2221 2231 

D b-- [nn Im nn [nn I] In Im Jen Inn [ann I [nn] 
$ 53248 1 53504 1 53760 1 54016 1 54272 1 54528 1 54784 I 55040 I 55296 1 55992 I 55808 I 56064 I 56320 I 56576 I 56832 I 57088 I 
222 ]==22222 [2222222 ][s22==== [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 [2222222 ]=222222]jss2esee]jesseeee]feneeeee]feeneeee]aeeenee] 
a a a a za 2a za 2 2 23 za 25 ua 27 2a 291 
EI I [m] Im II I [mn [nn I-- Ion] [one [ann] 
% 57344 1:57600 1 57856 I 58112 I 58368 I 58624 I 5B880 I 59136 I 59392 1 59648 I 59904 I 60160 I 60416 I 60672 I 60928 I 61184 I 
222 [2222222 [2222222 [2222222 ]2=222252 [2222222 [je22222=2 [2222222 [2222222 ]23==2=== [2202822 [2222222 [2022222 [22222] 2222222 »322===]==2=2====] 
es 201 211 221 231 21 251 21 2078 2a 2a 20 a a al 2551 

F bene [en I] I III I] I] [nn] 
% 61440 I 61696 I 61952 I 62208 I 62464 I 62720 I 62976 I 63232 I 63488 I 63744 1 64000 I 64256 I 64512 1 64768 I 65024 I 65280 I 
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3.5.4.3 Stufe 3: Speicherplatzinhalte mit POKE schreiben 


PEEKen können wir Speicherplätze des RAM und des ROM, während 
umgekehrt nur Speicherplätze des RAM gePOKEt und damit neu be- 
schrieben werden können. 
POKE 650,0 speichert die O0 in den Speicherplatz mit der Adres- 
se 650 ab. Man sagt: "poke die 0 nach 650" (nicht schön, aber 
kurz). Das zweite Argument muß zwischen 0 und 255 liegen. Die 
Anweisung POKE PLATZ,ZAHL speichert den Inhalt von ZAHL an die 
Adresse von PLATZ ab. Die Ausgabeschleife 

100 FOR I=1 TO 7 : READ C : POKE (10767+2),C : NEXT I 

110 DATA 101,6,101,6,133,8,96 
speichert die 7 in der DATA-Zeile angegebenen Zahlen in die 
Speicherplätze mit den Adressen 10768, 10769,... ab. 


Vor jedem Poken muß überlegt werden, ob nicht Speicherinhalte 
verändert werden, die für die Ablaufsteuerung wichtig sind. 
Zum "Üben" sei empfohlen, nur den Speicherplatz mit den Adres- 
sen 2048 - 40959 zu benutzen, d.h. den für die BASIC-Programme 
zur Verfügung stehenden Benutzerspeicher. 


Zum POKEn in den vom Betriebssystem beanspruchten Speicherbe- 
reich ein Beispiel: 
Durch Eingabe von 

POKE 650,128 /RET/ 
speichern wir die Zahl 128 in Adresse 650. Dadurch belegen wir 
alle Tasten mit der Repeatfunktion. Durch POKE 650,64 schal- 
ten wir das 'Repeat' ganz ab und durch POKE 650,0 wird unser 
System wieder in seinen Normalzustand gebracht, d.h. 'Repeat' 
gilt nur für die Cursorsteuerung. 
Das Betriebssystem verwendet also 650 als Adresse zum Umschal- 
ten der Repeatfunktion. 


Ein anderes Beispiel zum POKEn hatten wir in Abschnitt 3.9.2.5 
kennengelernt: Adressen 211 und 214 mit der Cursorposition im 
Programm BEFEHLSZEILEI. 


3.5.4.4 Stufe 4: Aufruf von Maschinenprogrammen 


Mit der Anweisung 

SYS 64738 
rufen wir ein Maschinenprogramm auf, dessen erster Befehl im 
Hauptspeicher unter der Adresse 64738 steht. 
Unter der Adresse 64738 beginnt beim Commodore 64 eine Rou- 
tine, die einen Warmstart bzw. ein RESET durchführt, die also 
den Commodore 64 in den Urzustand direkt nach dem Anschalten 
vesetzt. 
Das Handbuch nennt mehrere solche vom Betriebssystem bereitge- 
stellte Maschinenprogramme. 
Auch der Anwender kann Routinen in Maschinensprache (Assembler 
genannt) schreiben, im RAM ablegen und später mit SYS zur Aus- 
führung bringen. 
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Die Funktion USR() unterscheidet sich in zwei Punkten von der 
Funktion SYS: 

- Sprung in ein Maschinenprogramm, dessen Startadresse stets 
in den SPeicherstellen 785 und 786 (2-Bytes-Adresse, siehe 
Abschnitt 3.5.5) abgelegt ist. 

- USR(P) übergibt den Inhalt von P als Parameter an das Ma- 
schinenprogramm, um von diesem über den Parameter P ein 
bestimmtes Ergebnis zu erhalten. 


Auf das Erstellen von Maschinenprogrammen in Assembler können 
wir in dieser BASIC-Einführung nicht eingehen. 


3.5.5 Speicherung eines BASIC-Programms im RAM 


Bei Inbetriebnahme meldet sich der Commodore 64 mit: 
"64 K RAM SYSTEM 38911 BASIC BYTES FREE" 
Von diesen 64 K Bytes stehen uns als Anwender also 38911 Bytes 
zur Verfügung, und zwar in den Adressen 2048 - 40959. In die- 
sem Benutzerspeicher wird das BASIC-Programm sowie die zu ver- 
arbeitenden Daten (Variablen) zur Ausführungszeit abgelegt. 
Eine detaillierte Erklärung der Speicherorganisation würde den 
Umfang dieses Buchs sprengen. Gleichwohl wollen wir anhand des 
Beispielprogramms VERBRAUCH1I versuchen, die folgenden Fragen 
zu beantworten: 
- Wo ist das BASIC-Programm und wo sind die Variablen gespei- 
chert? 
- Wie sind die Anweisungen des Programms gespeichert? 
- Wie sind die Daten der Variablen gespeichert? 


3.5.5.1 Organisation des Anwenderspeichers 


In der Übersicht sind wichtige Adressen des Anwenderspeichers 
wiedergegeben. 

Durch Versetzen der Adresszeiger lassen sich Größe sowie Lage 
der Speicherbereiche verändern. 


Zunächst laden wir das Programm VERBRAUCH!I von der Diskette in 
den RAM. 
Über den direkten Dialog 

PRINT PEEK(43) + 256*PEEK(44) /RET/ 

2049 

READY. 
erfahren wir, daß das Programm VERBRAUCHI ab Adresse 2049 im 
RAM gespeichert ist. 
Eine mittels PEEK gelesene Adresse kann kann den Zahlenbereich 
0-255 nicht übersteigen (Byte mit 8 Bits). Aus diesem Grunde 
werden 2 Bytes verwendet, um auch auf höhere Adressen zeigen 
zu können. 
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Wichtige Adresszeiger für den Speicherbereich des Anwenders 


Begriff der 2 - Byte - Adresse: 

zei ge r der Form (Bytel,Byte2) sind 2-Byte-Adressen, die 
im Zahlenbereich 0-65535 liegen. (43,44) ist z.B. eine solche 
2-Byte-Adresse, bei der in Adresse 43 die niederwertigen Stel- 
len und in Adresse 44 die höherwertigen Stellen abgelegt sind. 
Um den dezimalen Wert der Speicheradresse zu erhalten, müssen 
wir den Inhalt des höherwertigen Bytes mit 256 multiplizieren. 
Grund: 256 (dezimal) entspricht $FF (hexadezimal) und damit 
dem binären Maximalwert 11111111 eines Bytes. 


Die Speicherbereiche für Arrays (Felder, Bereiche) sowie für 
Strings (Text, Zeichenketten) sind leer; Programm VERBRAUCH]I 
vereinbart ja auch keine Variablen der Datentypen String und 
Array. Die Adressen 2196 wie auch 40960 sind zugleich Anfangs- 
und Endeadressen der betreffenden Speicherbereiche. 


Alle Speicherbereiche werden von 'unten' nach 'oben' aufge- 
baut, d.h. in Richtung immer höherer Adressen. Eine Ausnahme 
bildet der String-Speicher, der von 'oben' nach "unten' aufge- 
baut wird (deshalb im Beispiel die Anfangsadresse 40960, die 
mit dem Ende des BASIC-Anwenderspeichers zusammenfällt). 
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3.5.5.2 Speicherung der Daten (Variablen) 


Im Variablen-Speicher ab Adresse 2168 sind die drei REAL-Vari- 
ablen T, K und D gespeichert. 
Im direkten Dialog schauen wir nach, wie diese Variablen abge- 
legt sind: | 
FOR I=2168 TO 2200: PRINT PEEK(I);: NEXT I /RET/ 
84 0 134 112 00075 0137 45 00068 O0 133 10 186 115 108 
(T) (K) (D) 
730140 9 1600 78 78 78 78 78 
(I) (N) ... 
READY. 
Die Variablennamen T, K, D, I und N erscheinen nicht; sie wur- 
den nur zur Erklärung eingefügt (in Klammern gesetzt). 
In Adresse 2168 steht die ASCII-Codezahl 84 bzw. der Buchstabe 
"PN (CHR$(84) ergibt T). In den Adressen 2175, 2182 sowie 2189 
finden wir die Variablennamen K, D und I (I als Laufvariable 
der von uns im direkten Dialog getippten FOR-Schleife). 
Jede Zahl vom Typ "REAL bzw. Dezimalzahl' wird vom Commodore 
in einem 7-Byte-Format gespeichert: 
- Bytes 1 und 2 für die ersten beiden Zeichen des Variablenna- 
mens (falls kein zweites Zeichen, dann 0). 
- Bytes 3 bis 7 speichern den Wert in einer normalisierten Ex- 
ponentialdarstellung als Gleitpunktzahl. 


Eine Zahl vom Typ "INTEGER bzw. Ganzzahl' beansprucht ebenso 

sieben Bytes: 

- Bytes 1 und 2 für die ersten beiden Zeichen des Namens (de- 
ren ASCII-Codezahlen jeweils um 128 erhöht). 

- Bytes 3 und 4 enthalten die Ganzzahl in der Darstellungsart 
(LowByte, HighByte). 

- Bytes 5 bis 7 unbenutzt bzw. 0. 


Mit dem folgenden Programm namens PEEKLESENI können wir das 
Speicherungsformat einer Real-Variablen namens T ausgeben las- 
sen. Da T die erste im Programm angesprochene Variable ist, 
wird sie auch unmittelbar am Anfang des Variablen-Speichers 
abgelegt. 


Bei Programm VERBRAUCHI lag der Beginn des Variablen-Spei- 
chers bei der Adresse 2168, während er bei Programm PEEKLESENI 
nun bei Adresse 2467 liegt. Grund: PEEKLESENI als das größere 
Programm beansprucht mehr Speicherplatz. 


Codierung zu Programm PEEKLESEN]: 


iaa REM ======PRÜGRAMM FEERLESENI 

118 PRINT "SFEICHERUNG EINER REAL-“ARIABLEN ZEIGEN. " 
120 INPUT "WERT EINER YWARIABLEN T": T 

130 : 

1409 LET ADR=PEEKi4S2+256#FEER 46) 

159 PRINT "T AB ADRESSE": ADR; "GESFEICHERT. " 

120 PEINT "WARIABLENNAME TH"SRADRSPUND"SRDE+1,":" 

17G FRINT FEEKCADR>:FEERSADR+1D 

158 PRINT "ZAHLENWERT IN"; ADR+Z:"BIE"SADR+SS "N 

120 FRINT FEEKÜRADR+22: FEERÜRDR+SSSFEEECRDR+4 2: FEEKSRDE +32: FEERCADRH+: 
288 FRINT "cWERT IN ERFOHENTIALDARSTELLUNG 3 FrTTES>" 
210 FRINT "ENDE." : END 
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Ausführung zu Programm PEEKLESENI: 


LOAD "PEEKLESEN1", 8 /RET/ 

RUN /RET/ 

SPEICHERUNG EINER REAL-VARIABLEN ZEIGEN. 
WERT EINER VARIABLEN T ? 1 /RET/ 

T AB ADRESSE 2467 GESPEICHERT. 
VARIABLENNAME IN 2467 UND 2468: 

84 0 

ZAHLENWERT IN 2469 BIS 2473: 

12930000 

ENDE. 


RUN /RET/ 

SPEICHERUNG EINER REAL=VARIABLEN ZEIGEN. 
WERT EINER VARIABLEN T ? 60 /RET/ 

T AB ADRESSE 2467 GESPEICHERT. 
VARIABLENNAME IN 2467 UND 2468: 

84 0 

ZAHLENWERT IN 2469 BIS 2473: 

134 112 000 

ENDE. 


3.5.5.3 Speicherung der Anweisungen (Programm) 


Nach der Ablage der Daten von Programm VERBRAUCHI wenden wir 
uns jetzt den Anweisungen dieses BASIC-Programms zu. Wie wir 
bereits wissen, sind die Anweisungen ab Adresse 2049 abgespei- 
chert. Im direkten Dialog erfahren wir, daß die Anweisungen 
gemäß ihrer Numerierung nach Zeilennummern 10, 20, .. fortlau- 
fend gespeichert sind: 

FOR 1=2049 TO 2079: PRINT PEEK(I1);: NEXT I /RET/ 

14 8 10 0 136 32 84 32 178 32 54 48 0 44 8 

( 10 LETb Tb = b 6 9 ‚ ) (b=Blanc) 


20 0 153 32 34 69 73 78 71 65 66 69 58 32 71 69 ... 
(20 PRINTTbD" EINGABE : b cG E ...) 
READY. 

Die Übersetzung der Codezahlen (in Klammern gesetzt) ist ein- 
gefügt. Sie zeigt, wie die ersten beiden Anweisungen LET sowie 
PRINT im RAM untergebracht sind. 
Die Zeilennummern 10 und 20 sind als 2-Byte-Adressen abgelegt 
(Zeilennummer 10 in Adressen 2051 (LowByte) sowie 2052 (High- 


Byte)). 
CHR$(153) steht für PRINT und CHR$(136) für LET, während der 
Zuweisungsoperator "=" durch die ASCII-Codezahl 178 verschlüs- 


selt ist. Auf diese Art werden alle Schlüsselworte von BASIC- 
Anweisungen (=reservierte Worte, Operatoren und Zeichen) abge- 
speichert. 

Ein 0O-Byte markiert das Ende einer BASIC-Anweisung (hier unter 
Adresse 2061). 
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Wir sind jetzt in der Lage, über PEEK und POKE unmittelbar die 
BASIC-Codierung eines im RAM befindlichen Programms zu ändern. 
Am Beispiel des Programms POKESCHREIBENI wollen wir die Zei- 
lennummer 320 (=letzte Zeile) in 400 abändern. 


Direkter Dialog: 

LOAD "POKESCHREIBEN1",8 /RET/ 

READY. 

PRINT PEEK(45)+256*PEEK(46) /RET/ 

2791 

READY. 

FOR I=2700 TO 2791: PRINT PEEK(I);: NEXT I /RET/ 

.. in Adressen 2773 und 2774 stehen 64 (LowByte) und 
1 (HighByte) .... 

READY. 
Der Programmspeicher endet also in 2791. Die Zeilennummer 320 
steht als (64,1) in den Adressen 2773 und 2774: 

PRINT PEEK(2773)+256*PEEK(2774) /RET/ 

320 

READY. 


Wir führen nun das Programm POKESCHREIBENI aus, um die Zeilen- 


Codierung zu Programm POKESCHREIBENI: 


150 REM LE: LOWBYTE FUER NIEDERWERTIGE STELLEN 
148 REM HR: HIGHEYTTE FUER HOEHERWMERTIGE STELLEH 
159 FEM DEZ: ZAHLENMERT 

168 FEM ADF: SPEICHERADRESSE FÜER DEZ 


156 IHPUT "ZAHLENMERT 20-655535>3"; DEE 

139 LET HE=INT(DEZ.'2568. 

288 LET LB=DEZ-256#HE 

2168 FRINT DEZ:" IN DER FORM SLOWBFTE. HIGHBYTEH: 
220 PRINT LE:",";HE 

238 INPUT "... AB WELCHER ADRESSE SPEICHERH" ADR 
249 POKE ADR.LE : FÜKE AOR+1.HE 

258 FRINT "ZAHL ALS 2-BYTE-ADRESSE GESFEICHERT. " 


=r8 PRINT:PRINT "LESEN ZUR KONTROLLE: " 

258 LET LE=SFEERKSAOR? : LET HE=FEEKGAIDR+L) 

238 LET DEZ=LE + 256#HB 

>59 FRINT "UNTER DER ADRESSE ©" ;ADR:"S"SADR+L: "5" 
318 FRINT "STEHT DER ZAHLENWERT" DEZ 

328 FRINT "ENDE." : EHD 
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nummer 320 durch die Nummer 400 zu ersetzen: 
RUN /RET/ 
DEMONSTRATION: 2-BYTE-ADRESSE SCHREIBEN. 
ZAHLENWERT (0-65535)? 400 /RET/ 
400 IN DER FORM (LOWBYTE,HIGHBYTE): 
144,1 
... AB WELCHER ADRESSE SPEICHERN? 2773 /RET/ 
ZAHL ALS 2-BYTE-ADRESSE GESPEICHERT. 


LESEN ZUR KONTROLLE: 

UNTER DER ADRESSE (2773,2774) 
STEHT DER ZAHLENWERT 400 
ENDE. 

READY. 


LIST /RET/ 

... Auflistung von Programm POKESCHREIBENI mit 
400 PRINT "ENDE." : END 

als letzter Anweisung ....«. 


Das Programm POKESCHREIBENI hat sich sozusagen "selbst umpro- 
grammiert': die Zeilennummer 400 hat die Nummer 320 ersetzt. 


3.5.6 Schnelle BASIC-Programme 


Bei rechenintensiven Programmen wie z.B. Sortierprogrammen ist 
Geschwindigkeit eines Programmlaufs von großer Bedeutung. Dazu 
drei Anmerkungen: 


1) Das 'normale' BASIC-Programm läuft schneller ab, wenn man 
REM-Anweisungen und Leerstellen wegläßt und die am häufigsten 
verwendeten Variablen am Programmanfang definiert (da die Va- 
riablentabelle sequentiell durchsucht wird). Ebenso sollte man 
die am häufigsten aufgerufenen Unterprogramme am Anfang stehen 
haben. 


2) Läßt man das Programm durch einen Compiler über- 
setzen, kann später bei jedem Programmlauf auf das bereits in 
Maschinenbefehle übersetzte Programm zurückgegriffen werden. 
Das Programm wird dadurch noch schneller. 


3) Ist auch das compilierte Programm zu langsam, kann man in 
Maschinensprache programmieren. Häufig kombiniert man 1) und 
3), in dem man im BASIC-Programm die rechenintensiven Routinen 
in der Maschinensprache (Assembler) programmiert, während die 
Ein- und Ausgabe in BASIC geschrieben bleibt. 
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3.6 Tabellenverarbeitung (Felder, Arrays) 


Mit der Tabellenverarbeitung wenden wir uns einer komplexeren 
Datenstruktur zu, die als Tabelle, Feld, Array, Bereich, Liste 
oder Matrix/Vektor bezeichnet wird. 


3.6.1 Tabellenverarbeitung im Überblick 


In Abschnitt 1.3.2.2 hatten wir als wichtige Datenstruktur den 
Array kennengelernt. Einen Array können wir uns als Regal mit 
mehreren Schubfächern als Elementen vorstellen. Je nach Inhalt 
der Fächer gibt es den Integer-Array (Ganzzahl; Name endet mit 
%-Zeichen wie M%), den Real-Array (Dezimalzahl; Name wie M) 
und den String-Array (Text; Name endet mit $-Zeichen wie M$). 
Eine am Programmbeginn stehende DIM-Anweisung legt den Array- 
Typ fest (durch %, $ bzw. ohne Typzeichen am Ende des Namens) 
sowie die Ausdehnung bzw. Dimension. 

DIM M(4) richtet einen Real-Array namens M mit 5 Elementen zur 
späteren Aufnahmen von Dezimalzahlen ein, wobei die Fächer mit 
M(O), M(1), M(2), M(3), M(4) durchnumeriert sind. 


Arrays Een Bereiche) 


Integer-Array M%: Real-Array M: String-Array M$: 





DIM M(4) DIM M$(4) 
M$(0) 
Eine M&(1) 
Dimen- M$(2) 
sion: M$(3) 
M$(4) 
DIM M$(3, 2) 
Zwei [HANS MAX EMIL 
Dimen- EVA KLAUS CARLA| 
slonen:z 


ERNST MARIA JULIA| 
MAX _LENA TILL | 





Drei Grundtypen von Arrays 


3.6.2 Eindimensionale Tabellen 


Eine eindimensionale Tabelle kann man sich waagerecht als Zei- 
le ode r senkrecht als Spalte angeordnet vorstellen, also 
immer in einer Richtung ausgedehnt. Man spricht dabei auch von 
Feld, Bereich, Vektor, Liste und natürlich Array. Das Programm 
LAGERREGAL1 veranschaulicht uns diese Datenstruktur: 

Mit 140 DIM R(7) vereinbaren wir ein Regal mit 8 Regalfächen 
0,1,...,7. Das 0. Fach lassen wir unberücksichtigt (man reser- 
viert es -wie später im Programm ABSATZTABELLEI gezeigt- meist 
für ganz besondere Eintragungen). Über die Eingabeschleife von 
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Zeile 210 bis 240 geben wir mittels 230 INPUT R(I) der Reihe 
nach 7 Zahlen in die Fächer 1,2,..,7 ein; dies können z.B. die 
Absatzmengen an den Wochentagen sein. 

Die Variable I bezeichnet man als windizierende Variable oder 
Index variable, da sie das jeweilige Element des Arrays R 
anzeigt. R(I) bedeutet: I. Stelle von R, I. Element von R bzw. 
R an der Stelle I. I ist zugleich auch Laufvariable der zZäh- 
lerschleife 210 FOR I=1 TO 7. 

Über die Schleife von Zeile 280 bis 300 wird als Übersicht die 
jeweilige Fachnummer (Index) samt der im Fach abgelegten Menge 
(Inhalt des Array-Elements) ausgegeben, wobei jeder Fachinhalt 
nach M aufsummiert wird. 


Index: R(0) R(1) R(2) R(3) R(4) 2 R(6) R(?7) 


Wert: 





leer Fächer Ii-7 mit je einer Zahl als Wert (Inhalt) 


- 140 DIM R(7) Reserviere 8 Fächer für einen Array R. 

- 149 LET R(2)=23 Weise die Zahl 23 ins 2. Regaäalfach zu. 

- 159 PRINT R{(4) Gib die 88 als Wert des 4. Faches aus. 

- 169 INPUT RI(6) Weise die Tastatureingabe ins 6. Fach zu. 

- 230 INPUT R(I) Weise die Tastatureingabe ins I. Fach zu, 
wenn I den Wert 3 hat, dann ins 3. Fach. 

- 291 LET M=M+R(2) Erhöhe M um den Wert des Z. Faches. 


Eindimensionale Tabelle bzw. Vektor R() als Beispiel 


Codierung zu LAGERREGAL]1: Ausführung zu LAGERREGAL]1: 
100 REM ======PROGRAMM LAGERREGALI1 LAGERREGAL ALS 1-DIM. FELD. 
110 PRINT "LAGERREGAL ALS 1-DIM. FELD." 

120 : EINGABE IN REGALFAECHER: 
130 REM ======VEREINBARUNGSTEIL MENGE FUER FACH 1: ?12 

140 DIM R(7): REM FELD(1..7) ALS REGAL MENGE FUER FACH 2: ?23 

150 REM I : INTEGER (LAUF-/INDEXVARIABLE) MENGE FUER FACH 3: ?11 

160 REM M : REAL (SUMME DER 7 FAECHER) MENGE FUER FACH 4: ?88 

170 : MENGE FUER FACH 5: ?24 

180 REM ======ANWEISUNGSTEIL MENGE FUER FACH 6: ?17 

190 REM *%**TASTATUREINGABE INS REGAL*****%** MENGE FUER FACH 7: 25 


200 PRINT : PRINT "EINGABE IN REGALFAECHER:" 
210 FOR I =1T07 FACH: MENGE: 


220 PRINT "MENGE FUER FACH ";I;": "; 1 12 
230 INPUT R(I) 2 23 
240 NEXT I 3 11 
250 : 4 88 
260 REM *%**VERARBEITUNG UND AUSGABE**k#*k#k* 5 24 
270 PRINT : PRINT "FACH: MENGE: " 6 17 
280 FOR I=1T0 7 7 5) 
290 PRINT I,R(I): LETM=M + R(I) SUMME: 180 


300 NEXT I 
310 PRINT "SUMME:",M 
320 END 
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Das folgende Programm VOKABELDRILL1I weist wie LAGERREGALI1 eine 
eindimensionale Tabelle auf. 

In den Fächern werden keine Zahlen aufbewahrt (Real-Array M), 
sondern Vokabeln als Texte (String-Arrays D$ und F$). Außer- 
dem richtet die Anweisung 150 DIM D$(A) keine feste Zahl von 
Fächern ein, sondern soviele, wie über die vorausgegangene An- 
weisung 140 INPUT A durch Tastatureingabe festgelegt wurde. 
In der Ausführung sind es A=3 Fächer für je drei deutsche und 
französische Vokabeln (Fächer 0 bleiben leer). Man bezeichnet 
INPUT A: DIM D$(A) als dynamisch e Dimensionierung. 


Das Programm VOKABELDRILL! ist natürlich erweiterungsbedürftig 
(Zufallsauswahl von Vokabeln; Antwortanalyse für Fehlerhinweis 
und Ablaufmodifikation; Ablage von Vokabeln in Dateien; ... ). 
Vielleicht versuchen Sie es einmal mit einer Erweiterung? 


Codierung zu VOKABELDRILLI1: Ausführung zu VOKABELDRILLI: 
100 REM ======PROGRAMM VOKABELDRILL1 DRILL FRANZOESISCH-DEUTSCH. 
110 PRINT "DRILL FRANZOESISCH-DEUTSCH. " ANZAHL DER VOKABELN: 3 
120 : PAARWEISE TIPPEN: D , F 
130 REM ======VEREINBARUNGSTEIL ?MANN , HOMME 

140 INPUT "ANZAHL DER VOKABELN: ";A ?FRAU, FEMME 

150 DIM D$(A): REM STRING-ARRAY FUER D ?KIND,ENFANT 

160 DIM F$(A): REM STRING-ARRAY FUER F 

170 REM A$: STRING (JEWEILIGE ANTWORT) BEGINN DER UEBUNG: 

180 : MANN <- ?HOMME 

190 REM ======ANWEISUNGSTEIL GUT. 

200 PRINT "PAARWEISE TIPPEN: D , F" FRAU <- ?DAMME 

210 FOR I=1T0A FALSCH. FRAU -> FEMME 

220 INPUT D$(I),F$(I) KIND <- ?ENFANT 

230 NEXT I GUT. 

240 PRINT : PRINT "BEGINN DER UEBUNG: " ENDE. 

250 FOR I=1TOA 

260 PRINT D$(I);'" <- ";: INPUT A$ 


270 IF A$ = F$(I) THEN PRINT '"GUT.": GOTO 290 
280 PRINT "FALSCH. ";D$(I);" -> ";F$(CI) 

290 NEXT I 

300 PRINT "ENDE.": END 


3.6.3 Zweidimensionale Tabellen 


Eine zweidimensionale Tabelle dehnt sich waagerecht in Zeilen 
und senkrecht in Spalten aus. Am Beispiel der durch DIM R(2,S) 
dynamisch vereinbarten Tabelle wollen wir diese Datenstruktur 
im Programm ABSATZTABELLE1 näher betrachten. 


R(5,4) kann man sich als Schrank vorstellen zur Aufnahme der 
Absatzmengen von 5 Kunden (=Zeilen 1 bis 5) in den 4 Quartalen 
(=Spalten 1 bis 4). So hat Kunde 5 im 1. Jahresquartal 50 Stk. 
gekauft und Kunde 3 im 3. Quartal 90 Stk. 
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Die Tastatureingabe der 5*%4=20 Absatzmengen vollzieht sich in 
den Zeilen 210-270 über zwei geschachtelte Zählerschleifen mit 


210 FOR I=1 TO 2 Äussere Schleife "Kunden 1,2,3,4,5' 

230 FOR J=1 TO S Innere Schleife "Quartale 1,2,3,4' 
250 INPUT R(I,J) Eingabe nach Fach Zeile I, Spalte J 
260 NEXT J Innere Schleife beenden 

270 NEXT I Äussere Schleife beenden 


viermaligem Durchlaufen der inneren Schleife für jeden Kunden. 


Codierung zu ABSATZTABELLEI: 


100 REM ======PROGRAMM ABSATZTABELLEI 

110 PRINT "TABELLENVERARBEITUNG: " 

120 PRINT "KUNDE-VIERTELJAHR ALS 2-DIM. FELD." 
130 : 

140 REM ======VEREINBARUNGSTEIL 

150 INPUT "ANZAHL DER ZEILEN (WAAGERECHT):";Z 
160 INPUT "ANZAHL DER SPALTEN (SENKRECHT: ";S 
170 DIM R(Z,S): REM REGAL 

180 : 

190 REM ======ANWEISUNGSTEIL 

200 PRINT : PRINT "EINGABE ZEILENWEISE:" 

210 FOR I =1T0Z 

220 PRINT '"NAECHSTE ZEILE, NAECHSTER KUNDE: " 
230 FOR J = 1T0S 

240 PRINT "KUNDE "515", VIERTELJAHR ";J;": "; 
250 INPUT R(I,J) 

260 NEXT J 

270 NEXT I 

280 : 

290 REM *%**ZEILENWEISE SUMMIERENBRBRSKSKSSSKSKSSKSKSHREKKUK 
300 FOR I=1T02Z 


310 FOR J = 1 T0S 

320 LET R(I,O) = R(I,0) + R(I,J) 
330 NEXT J 

340 NEXT I 

350 : 


370 FOR I = 1 TO Z:R(0,0) = R(0,0) + R(I,0): NEXT I 


380 : 

390 REM *%**SPALTENWEISE SUMMIEREN?* #3 3kak aka 
400 FOR J = 1 TOS 

440 FOR I=1T0Z 

420 LET R(0,J) = R(0,J) + R(I,J) 

430 NEXT I 

440 NEXT J 

450 : 


460 PRINT : REM ***AUSGABE ALS UEBERSICHT*F*#+x#xkxH%* 
470 PRINT "UEBERSICHT "525" -> UND ";5;" *;" 

480 FOR I =0T0Z 

490 FOR J=0T0S 

500 PRINT R(I,J);" "; 

510 NEXT J 

520 PRINT 

530 NEXT I 

540 PRINT "ENDE.": END 
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Das Verarbeiten von zweidimensionalen Tabellen (auch Matrizen 
genannt) führt stets zur Schleifenschachtelung . 

Die Fächer mit 0 als Index werden häufig zur Ablage besonderer 
Werte verwendet. In Programm ABSATZTABELLEI werden in Zeile 0 
die Quartalssummen 150,300,450,600 abgelegt, also die 4 Spal- 
tensummen. In Spalte O0 finden wir die Kundenabsatzmengen 100, 
200,300,400,500 als die 5 Zeilensummen. Im Fach R(0,0) ist die 
Gesamtjahresabsatzmenge 1500 gespeichert. Das zeilen- wie auch 
das spaltenweise Summieren läuft wieder über Schleifenschach- 


telungen ab. 
| 1500 158771 300 450 600 | 
H - | (waagerecht) und 5 
| Spalten (senkrecht) 


R(1,0) | R(1,1) [R(1,2) | R(1,3) [RI | 
100 19. 4 20 30 | ein, also 20 Fächer. 


r#) 
0 

r | 
0 








DIM Ri5,4) richtet 
Tabelle mit 6 Zeilen 






4 
R(2,0) | R(2,1) |r(2,2) | R(2,3) |R(2,4) | 
200 20 40 60 8 
R(3,0) | R(3,1) |Ir(3,2) | R(3,3) |r(3,4) | 
300 30 60 90 120%) 
r 5 


| R als Regalschrank. 


LET R(4,3)=120 weist 
dem Fach in Zeile 4 
und Spalte 3 die 120 
ZUus 









PRINT R(I,2) gibt 
Spalte 2 aus, wenn I 
von 0 bis 5 läuft. 


R(4,0) |R(4,1) |R(4,2) | R(4,3) |R(4,4) 
400 40 80 120 160 
R15,. 03-1 RISFIT IRLSFZT I RIS, 3 I RI, 

500 50 100 150 | 7200 


Zweidimensionale Tabelle bzw. Matrix R(5,4) als Beispiel 





Ausführung zu ABSATZTABELLEI: KUNDE 3, VIERTELJAHP 3: 290 
KUNDE 3, VIERTELJAHR 4: ?120 

TABELLENVERARBEITUNG: NAECHSTE ZEILE, NAECHSTER KUNDE: 

KUNDE-VIERTELJAHR ALS 2-DIM. FELD. KUNDE 4, VIERTELJAHR 1: ?40 

ANZAHL DER ZEILEN (WAAGERECHT) :5 KUNDE 4, VIERTELJAHR 2: ?80 

ANZAHL DER SPALTEN (SENKRECHT: 4 KUNDE 4, VIERTELJAHR 3: ?120 
KUNDE 4, VIERTELJAHR 4: ?160 

EINGABE ZEILENWEISE: NAECHSTE ZEILE, NAECHSTER KUNDE: 

NAECHSTE ZEILE, NAECHSTER KUNDE: KUNDE 5, VIERTELJAHR 1: ?50 

KUNDE 1, VIERTELJAHR 1: ?10 KUNDE 5, VIERTELJAHR 2: ?100 

KUNDE 1, VIERTELJAHR 2: ?20 KUNDE 5, VIERTELJAHR 3: ?150 

KUNDE 1, VIERTELJAHR 3: ?30 KUNDE 5, VIERTELJAHR 4: ?200 

KUNDE 1, VIERTELJAHR 4: 240 | Ä 

NAECHSTE ZEILE, NAECHSTER KUNDE: UEBERSICHT 5 > UND 4 A: 

KUNDE 2, VIERTELJAHR 1: ?20 | 1500 150 300 450 600 

KUNDE 2, VIERTELJAHR 2: ?40 100 10 20 30 40 

KUNDE 2, VIERTELJAHR 3: ?60 200 20 40 60 80 

KUNDE 2, VIERTELJAHR 4: ?80 300 30 60 90 120 

NAECHSTE ZEILE, NAECHSTER KUNDE: 400 40 80 120 160 

KUNDE 3, VIERTELJAHR 1: ?30 500 50 100 150 200 


KUNDE 3, VIERTELJAHR 2: ?60 ENDE. 
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Neben ein- und zweidimensionalen Tabellen lassen sich auch 
Tabellen mit mehr als zwei Ausdehnungen in Commodore-BASIC be- 
handeln. 

Hier ein Beispiel zu einem dreidimensionalen Array: 
Bundesligatabelle(n) mit 18 Zeilen (=18 Vereine), 7 Spalten 
(=7 Eintragungen je Verein wie Name, Tore, Punkte ...) und mit 
34 'Tiefen' (=34 Spieltagen). 


Die Tabellenverarbeitvung wird häufig mit 

der Dateiverabe wit ung wie folgt kombiniert: 

- Aus einer Datei werden Datensätze in den Hauptspeicher ein- 
gelesen und in einem eindimensionalen (Vektor) oder zweidi- 
mensionalen Array (Matrix) abgelegt. 

- Diese Datensätze können nun bequem im Direktzugriff bearbei- 
tet werden. 

"Direktzugriff' bedeutet, daß auf jedes Datenelement eines 
Arrays über den Index direkt zugegriffen werden 
kann. 

- Abschließend schreibt man die Daten aus dem (den) Array(s) 
wieder auf die Disketten-Datei zurück. 

In Abschnitt 3.8 werden wir diese Verbindung von Tabelle bzw. 

Array einerseits und Datei bzw. File andererseits näher erklä- 

ren. 


3.7 Suchen, Sortieren, Mischen und Gruppieren von Daten 


3.7.1 Verfahren im Überblick 


Legt man einen größeren Datenbestand als Dat ei auf einem 
Externspeicher ab, dann stellen sich immer wieder Probleme des 
Suchens, Sortierens, Mischens sowie Gruppierens von Datensätz- 
en der Datei. Aus diesem Grunde bezeichnet man diese vier Ver- 
fahren oft als Hilfsmittel der Dateiverarbeitung. Ob man Sätze 
einer Datei sortiert oder Komponenten eines Arrays - am jJewei- 
ligen zu demonstrierenden Verfahren ändert dies meist nichts; 
aus diesem Grunde verarbeiten die folgenden Beispiele Arrays. 


SUCHEN: Absatzmengen Mo - So: 45,100,95,78,90,76,80. 
An welchem Tag wurden 78 Stück abgesetzt? 


SORTIEREN: Absatzmengen in aufsteigende Sortierfolge 
45,76,78,80,90,35,100 bringen. 


MISCHEN: Mengen 45,76,78,80,90,35,100 von Filiale 1 und 
Mengen 30,47,55,57,61,80,103 von Filiale 2 zu 
30,45,47,55,57,61,76,78,80,80,90,95,100,103 
als Gesamtliste mischen. 


GRUPPIEREN: Gruppensummen MO-MI=240 und DO-S0=324 bilden. 


Vier Hilfsverfahren der Dateiverarbeitung 
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3.7.2 Suchverfahren 


Das einfachste Suchverfahren besteht darin, die Datei Satz für 
Satz in der Reihenfolge der Speicherung zu durchsuchen. Dieses 
serie 1 1 e Suchen ist typisch für die Datentäger Magnet- 
band bzw. Kassette. Eine Adreßdatei nach ZIMMERMANN zu durch- 
suchen kann ggf. sehr lange dauern. Im Programm SUCHBINAERI 
wird das bi nä re Suchen als schnelles Suchverfahren dar- 
gestellt. 
- Die Daten müssen stets sortiert und auf einem Direktzugriff- 
speicher vorliegen (hier die 7 Werte 45,76,78,80,90,95,100). 
- Das Wort "'binär bzw. zweiwertig' deutet an, daß man stets 
die Hälfte bildet. Um die Menge 90 zu suchen (siehe Ausfüh- 
rungsbeispiel), wird zunächst die Menge 80 als Mitte genom- 
men (7 Mengen, 3.5 ergibt gerundet die 80 als die 4. Menge). 
- Der Vergleich 80<90 zeigt, daß in der oberen Hälfte 90 - 100 
weiterzusuchen ist. Man nimmt wieder die Mitte und der vVer- 
gleich 95>90 zeigt, daß jetzt in der unteren Hälfte weiter- 
zusuchen ist. Da in dieser Hälfte nur noch der Suchbegriff 
90 steht, wird die Suche als "positiv' beendet. 
Bei diesem kleinen Beispiel mag das binäre Suchen umständlich 
wirken. Das Leistungsvermögen dieses Suchverfahrens zeigt das 
folgende Beispiel: Um aus den über 60 Millionen Bundesbürgern 
ei nen Namen herauszufinden, werden nur 26 Zugriffe benö- 
tigt (6 Zugriffe für 64 Bürger (2 hoch 6 gleich 64) und 26 Zu- 
griffe für über 60 Mio Bürger (2 hoch 26 gleich 67108864)). 


Codierung zu Programm SUCHBINAER]: PAP zu SUCHBINAER!]: 
100 REM ======PROGRAMM SUCHBINAERI 

110 PRINT "METHODE DES BINAEREN SUCHENS." 

120 : 

130 REM ======VEREINBARUNGSTEIL 

140 REM A: INTEGER (ANZAHL DER DATEN) 


150 REM DC): FELD (DATEN ALS SUCHGEGENSTAND) 

160 REM UNTEN,MITTE,OBEN: INTEGER (GRENZEN) 

170 REM GEFUNDEN: BOOLEAN (-1 ODER O FÜER DAS ERGEBNIS) 
180 : 

190 REM ======ANWEISUNGSTEIL 

200 INPUT "ANZAHL DER DATEN: ";A: DIM D(A) 

210 PRINT A;" DATEN EINZELN EINTIPPEN:' 

220 FOR I = 1 TO A: INPUT D(I): NEXTI 

230 LET GEFUNDEN = O:UNTEN = 1:0OBEN = A 

240 INPUT "SCHLUESSEL ALS SUCHBEGRIFF: ";S 

250 PRINT : PRINT "SUCHPROTOKOLL:" 

260 REM *%**NICHT-ABWEISENDE SUCHSCHLEIFEFFKKKKKRKRK 
270 LET MITTE = INT ((UNTEN + OBEN) / 2) 

280 PRINT "UNTEN: ";UNTEN;", MITTE: ";MITTE;", OBEN: ";OBEN 
290 IF S > D(MITTE) THEN UNTEN = MITTE + 1 

300 IF S < D(MITTE) THEN OBEN = MITTE - 1 

310 LET GEFUNDEN = S = D(MITTE) 

320 IF (UNTEN < = OBEN) AND (GEFUNDEN = 0) THEN 270 
330 REM 3%®k*ZWEISEITIGE AUSWAHLFFKKKKKKKKKRKKKRRIUCIRRIRRIEIEC 
340 PRINT : PRINT "SUCHERGEBNIS: "; 

350 IF GEFUNDEN THEN PRINT "GEFUNDEN.'": GOTO 370 
360 PRINT "NICHT GEFUNDEN." 

370 PRINT "ENDE.": END 
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Zur Codierung von SUCHBINAER]: 
In der rechten Hälfte des jeweiligen Suchbereichs wird weiter- 


gesucht, 
rückt (in Zeile 290). 


steuerung. Ist in Zeile 310 S gleich D(MITTE), dann wird 
'wahr ' 


als Vergleichsergebnis 


indem man die Hälfte-Grenze UNTEN auf die MITTE vor- 
Die Variable GEFUNDEN dient der Ablauf- 


oe: 0. 


nach GEFUNDEN zugewiesen. Im an- 


deren Fall behält GEFUNDEN den Wert '0'. 


Ausführungen zu Programm SUCHBINAERI: 


METHODE DES BINAEREN SUCHENS. 
ANZAHL DER DATEN: 7 

7 DATEN EINZELN EINTIPPEN: 
245 

?76 

278 

780 

790 

795 

?100 

SCHLUESSEL ALS SUCHBEGRIFF: 90 


SUCHPROTOKOLL: 

UNTEN: 1, MITTE: 4, OBEN: 7 
UNTEN: 5, MITTE: 6, OBEN: 7 
UNTEN: 5, MITTE: 5, OBEN: 5 


SUCHERGEBNIS: GEFUNDEN. 
ENDE. 


3.7.3 Sortierverfahren 


Die ersten 


METHODE DES BINAEREN SUCHENS. 
ANZAHL DER DATEN: 5 

5 DATEN EINZELN EINTIPPEN: 

?1000 

22000 

23000 

25000 

?9000 

SCHLUESSEL ALS SUCHBEGRIFF: 1000 


SUCHPROTOKOLL: 
UNTEN: 1, MITTE: 3, OBEN: 5 
UNTEN: 1, MITTE: 1, OBEN: 2 


SUCHERGEBNIS: GEFUNDEN. 
ENDE. 


Programme der Datenverarbeitung sollen Sortierpro- 


gramme gewesen sein. Dies unterstreicht die Bedeutung des Sor- 
tierens gerade für die kaufmännische DV. Es läßt aber auch er- 


ahnen, 


Sortieren ...! 


INTERN - EXTERN 


NUMERISCH - STRING 


DATEN - ADRESSEN 


EINFACH - KOMPLEX 


wie raffiniert heutige Sortieralgorithmen sein können. 


.. bedeutet: 


Daten im Internen Speicher (HS) 
oder auf einem Externen Speicher. 


Daten als Zahlen (1 < 4< 8,5) 
oder als Text ($ < DM < LIRE). 


Daten selbst sortieren oder nur 
deren Adressen bzw. Speicherplätze. 


Einfache Sortierverfahren wie Aus- 
wahl, Bubble Sort, Einfügen oder 
komplexe Verfahren wie Sortieren 
durch Mischen, Binär-Baum-Sort, 
Quick Sort mittels Rekursion. 


Vier Begriffspaare zum Sortieren 
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Die folgenden Beispiele gehen weder auf das Externe Sortieren 
ein (erforderlich, wenn Datenumfang den Speicherplatz des In- 
ternspeichers übersteigt) noch auf komplexere Sortierverfahren 
ein. 


Stade zahlen unmittelbar sortieren 


'Unmittelbar' heißt, daß wir die zu sortierenden Zahlen selbst 
umordnen und nicht - wie im nächsten Abschnitt - ihre Plätze. 
Das Programm SORTDATENI! wendet das Sortierverfahren "Austausch 
nach Auswahl" an. 





Sortierverfahren "Austausch nach Auswahl" ein einem Beispiel 


Die Markierung "I" soll anzeigen, daß bei jedem Durchlauf mit 

D(I+1) begonnen wird, daß D() also verkürzt wird; programmiert 

wird das Verkürzen durch den Anfangswert I+1 win der Anweisung 
190 FOR J = I+1 TO 6. 

Das Tauschen von D(I) mit D(MINSTELLE) vollzieht sich über die 

Methode des Dre ieckstausches. Dabei verwenden 

wir die Stelle 0 des Arrays D() als Hilfsvariable. 





Methode des Dreieckstausches an zwei Beispielen 
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Struktogramm zu Programm SORTDATENI: 


Eingabe: 6 Zahlen nach D() aus DATA-Zeile programmintern 


Für I von 1 bis 5 wiederhole 


MINSTELLE = I als vorläufiges Minimum festlegen 


Für J von (I+1) bis 6 wiederhole 


MINSTELLE = J als 
neues Minimum 


Austausch von D(I) und D(MINSTELLE) mittels 
Dreieckstausch über D(0) als Hilfsvariable: 
D(0O) = D(I) 

D(I) = D(MINSTELLE) 
D(MINSTELLE) = D(0) 


Ausgabe der 6 in D() aufsteigend sortierten Zahlen 





SORTIEREN DURCH AUSTAUSCH NACH AUSWAHL 


(SORTIEREN DER DATEN SELBST). Ausführung zu SORTDATEN!: 
DATEN: 

102 101 109 106 104 105 

SORTIERPROTOKOLL: DATEN SORTIERT: 

102 101 109 106 104 105 101 102 104 105 106 109 

101 102 109 106 104 105 ENDE. 


101 102 109 106 104 105 
101 102 104 106 109 105 
101 102 104 105 109 106 
Codierung zu SORTDATENI: 


100 REM ======PROGRAMM SORTDATENI 

110 PRINT "SORTIEREN DURCH AUSTAUSCH NACH AUSWAHL" 
120 PRINT "(SORTIEREN DER DATEN SELBST) ." 

130 PRINT "DATEN:" 


140 FOR I = 1 TO 6: READ D(I): PRINT D(I);" ";: NEXT I 
150 DATA 102,101,109,106,104,105 

160 : | 

161 PRINT : PRINT : PRINT "SORTIERPROTOKOLL:" 

170 FOR I=1T105 

171 FOR Y = 1 TO 6: PRINT D(Y);" "3: NEXT Y: PRINT 


180 LET MINSTELLE = I 

190 FOR J=1I+1T06 

200 IF D(J) < D(MINSTELLE) THEN LET MINSTELLE = J 

210 NEXT J 

220 LET D(0O) = D(I):D(I) = D(MINSTELLE):D(MINSTELLE) = D(O) 
230 NEXT I 


240 : 
250 PRINT : PRINT "DATEN SORTIERT: " 
260 FOR I = 1 TO 6: PRINT D(I);" ";: NEXT I 


270 PRINT : PRINT "ENDE.": END 
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3.7.3.2 Zahlen über Zeiger sortieren 


Im Programm SORTDATENI haben wir sechs Zahlen selbst mehrfach 
umgeordnet. Bei umfangreicheren Datenbeständen kann es günsti- 
ger sein, nur die Speicherplätze dieser Zahlen über Zeigerva- 
riablen bzw. Po inter zu sortieren, die Zahlen selbst 
unbewegt zu lassen. Programm SORTZEIGER! demonstriert dies mit 
denselben Daten und demselben Sortierverfahren wie in Programm 
SORTDATEN]: 





Unmittelbares Sortieren sowie Sortieren über Zeiger 


Ausführung zu SORTZEIGER]: Datenflußplan zu SORTZEIGER]: 


SORTIEREN DURCH AUSTAUSCH NACH AUSWAHL 


(SORTIEREN UEBER ZEIGER). Eingabe 
DATEN: über 

102 101 109 106 104 105 Tastatur 
ZEIGER: 


123456 


SORTIERPROTOKOLL DER ZEIGER: | 

12 345.6 Sortieren 
2134 

2134 

2154 

2156 | 


w wu un (in 
OOo 


EIGER SORTIERT: 
215643 

DATEN SORTIERT: 

101 102 104 105 106 109 
ENDE. 


N 


Druck - 
ausgabe 
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Codierung zu Programm SORTZEIGER!: 


100 REM ======PROGRAMM SORTZEIGER1 

110 PRINT "SORTIEREN DURCH AUSTAUSCH NACH AUSWAHL" 

120 PRINT "(SORTIEREN UEBER ZEIGER)." 

130 PRINT "DATEN:" 

140 FOR I = 1 TO 6: READ D(I): PRINT D(I);" ";: NEXTI 
150 DATA 102,101,109,106,104,105 

160 PRINT : PRINT "ZEIGER:" 


170 FOR I = 1 TO 6: LET Z(I) = I: PRINT Z(I);" ";: NEXTI 
180 : 

181 PRINT : PRINT : PRINT "SORTIERPROTOKOLL DER ZEIGER:" 
190 FOR I =1T05 

191 FOR Y = 1 TO 6: PRINT Z(Y);" "s: NEXT Y: PRINT 


200 LET STELLEMIN = I 

210 FOR J=1I+1T06 

220 IF D(J) < D(Z(STELLEMIN)) THEN STELLEMIN = J 

230 NEXT J 

240 LET Z(0) = Z(I):Z(I) = Z(STELLEMIN):Z(STELLEMIN) = Z(0) 
250 NEXT I 


260 : 

270 PRINT : PRINT "ZEIGER SORTIERT:" 

280 FOR I = 1 TO 6: PRINT Z(I);" ";: NEXT I 
290 PRINT : PRINT "DATEN SORTIERT: " 

300 FOR I = 1 TO 6: PRINT D(Z(I));" ";: NEXT I 


310 PRINT : PRINT "ENDE.": END 


3.7.3.3 Strings unmittelbar sortieren 


Programm SORTDATEN2 veranschaulicht das Sortieren von Strings 
anhand des "Sortierens durch paarweisen Austausch", das häufig 
auch Bubble Sort genannt wird. Die zu sortierenden Namen sind 
im String-Array N$() abgelegt und werden paarweise verglichen, 
um bei falscher Sortierfolge ausgetauscht zu werden. Dazu das 


Ausführungen zu Programm SORTDATEN2: 


SORTIEREN DURCH PAARWEISEN AUSTAUSCH 
ALS "BUBBLE SORT' (SORTIEREN VON TEXT, 


ZEICHENKETTEN BZW. STRINGS SELBST). ANZAHL DER NAMEN: 5 
5 NAMEN EINZELN TIPPEN: 

ANZAHL DER NAMEN: 4 2126 DM 

4 NAMEN EINZELN TIPPEN: ?FILTER MIT 

?MAX 2526.50 

?MARIA 225500 LIRE 

?TILLMANN 2%-SAETZE 

?LENA 
NAMEN AUFSTEIGEND SORTIERT: 

NAMEN AUFSTEIGEND SORTIERT: $26.50 

LENA 2-SAETZE 

MARIA 126 DM 

MAX 25500 LIRE 


TILLMANN FILTER MIT 
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erste Ausführungsbeispiel zu SORTDATEN2: MAX<MARIA falsch und 
Austausch, MAX<TILLMANN wahr, TILLMANN<LENA falsch und Aus- 
tausch. Jetzt MARIA,MAX,LENA,TILLMANN gespeichert. Wie Blasen 
(=bubble) werden Worte "hochgesprudelt', d.h. an das Ende des 
Arrays N$() gerückt. 

Die Variable F steuert als Flagge (Flag) den Ablauf: "Flagge 
oben' bedeutet "Wort ist ausgetauscht'. Die Schleife wird so- 
lange durchlaufen, bis F unten bleibt. 

Wie die zweite Ausführung zu SORTDATEN2 zeigt, kann Text mit 
beliebigen Zeichen sortiert werden. Warum kommt z.B. Strina 
"$-SAETZE" vor String "126 DM"? Da die ASCII-Codezahl 37 (für 
das %) vor der ASCII-Codezahl 49 (für die 1) angeordnet ist. 


Codierung zu Programm SORTDATEN2: 


100 REM ======PROGRAMM SORTDATEN2 

110 PRINT "SORTIEREN DURCH PAARWEISEN AUSTAUSCH" 
120 PRINT "ALS "BUBBLE SORT' (SORTIEREN VON TEXT," 
130 PRINT "ZEICHENKETTEN BZW. STRINGS SELBST) ." 
140 : 

150 PRINT : INPUT "ANZAHL DER NAMEN: "sA 

160 DIM N$(A) 

170 PRINT A;" NAMEN EINZELN TIPPEN:" 

180 FOR I = 1 TO A: INPUT N$(I): NEXT I 

190 LET F = O0: REM FLAGGE F GESENKT 

200 FOR I=1T0O (A-|]1) 

210 IF N$CI) < = N$(I + 1) THEN 240 


220 LET H$ = N$(I):N$(I) = N$CI + 1):N$(I + 1) = H$ 
230 LET F = 1: REM FLAGGE F OBEN 

240 NEXT I 

250 IFF< > 0 THEN 190 

260 : 


270 PRINT : PRINT "NAMEN AUFSTEIGEND SORTIERT:" 
280 FOR I = 1 TO A: PRINT N$(I): NEXT I 
290 END 


Struktogramm zu SORTDATEN2: 










Eingabe: Anzahl A und dann A Wörter in den Array N$() 


Flagge F=0 setzen, also senken 


Für I von 1 bis (A-1) wiederhole 


N$(I)<= N$(I+l) 
Austausch vornehmen 
von N$(I) und N$(I+1) , 
Flagge F=1 heben 


Wiederhole, bis F=0 bleibt, d.h. bis kein Austausch mehr 











Ausgabe der A in N$ abgelegten Wörter aufsteigend sortiert 
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3.7.4 Zwei Arrays mischen 


Mischen heißt, Daten unter Berücksichtigung ihrer Sortierfolge 
zu einer Datenstruktur zusammenzufügen. Im Beispielpro- 
gramm MISCHDATENI! wird der 5-Elemente-Aray X() und der 4-Ele- 
mente-Array Y() zum 9-Elemente-Array Z2() gemischt. Ein Problem 
beim Mischen besteht in der Ende-Verarbeitung, wenn ein Array 
bereits vollständig eingemischt ist. In MISCHDATENI wird dann 
in ein zusätzliches 6. (für X) bzw. 5. (für Y) Element die 999 
als große Zahl gespeichert, um den Array für das weitere Ein- 
mischen zu sperren. Die Anweisung dazu heißt: 

LET X(6) = ABS(999 * (I=6)) 
Hat I den Wert 6, so wird der Vergleich I=6? zu -1 (also wahr) 
und X(6) erhält den Wert ABS(999*-1), d.h. 999. Für die übri- 
gen Werte von I bleibt X(6) Null, da der Vergleich 1I=6? zu 0 
(also unwahr) führt. 


Codierung zu Programm MISCHDATEN!: 


100 REM ======PROGRAMM MISCHDATENI1 
110 DIM X(6): DIM Y(5): DIM Z(9) 


120 FOR I = 1 TO 5: READ X(I): NEXT I 
130 FOR I = 1 TO 4: READ Y(I): NEXT I 
140 LETI=1: LETJ=1: LETK=1 


150 REM *%*%* SCHLEIFENBEGINN ZUM MISCHEN etskakakstslsllitktekekekekkikikikikikikikikikikikikikikikikk 
160 IF X(I) = 999 AND Y(J) = 999 THEN 210 

170 IF XCI) < = Y(J) THEN Z(K) = X(I):I = I + 1:X(6) = ABS ((I = 6) * 999): 
180 LET Z(K) = Y(J):J = J + 1:Y(5) = ABS ((J = 5) * 999) GOTO 190 
190 LET K = K + 1: GOTO 160 

200 REM *** SCHLEIFENENDE *%*%*%akaakakaaksiakskikksiaisisiigisksisisisiaieigtefokakikikaisieieiefskekakikikakakiick 
210 PRINT "DATENBESTAENDE 1 UND 2 GEMISCHT: " 

220 PRINT : FOR K = 1 TO 9: PRINT Z(K);" ";: NEXTK 

230 : 

240 DATA 10,20,30,40,50: REM DATENBESTANDI 

250 DATA 15,20,25,45 : REM DATENBESTAND2 

260 END 


Ausführung zu MISCHDATENI1: Struktogramm zu MISCHDATENI: 


Eingabeteil 


Wiederhole solange ungleich 999 


Datenflußplan zu Programm MISCHDATENI!: 





RUN 
DATENBESTAENDE 1 UND 2 GEMISCHT: 





Datenbestand 1: X(5) 


m 5 Gemischter Daten- 
[| \V bestand 3: 2(9) 


Datenbestand 2: Y(4) 
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3.7.5 Gruppieren von Daten (Gruppenwechsel) 


Das Programm GRUPPDATENI erwartet über Tastatur die Mengen- 
angaben zu Aufträgen, um bei Wechsel der Auftragsnummer deren 
Summe auszugeben. Aufträge mit gleicher Nummer werden zu Grup- 
pen zusammengefaßt, um bei Gruppenwechsel deren Summe auszuge- 
ben. Solche Probleme bezeichnet man als Verdichten 
von Daten oder als Gruppenwechse |]. Wie wird der 
Gruppenwechsel in GRUPPDATEN! festgestellt? Wir unterscheiden 
A2 für "Auftrag neu' und Al für "Auftrag alt', um für (A2<&Al) 
dann die jeweils nach SI aufaddierte Summe auszugeben und mit 
220 LET S1=0 : LET Al=A2 zum nächsten Datensatz überzugehen. 


Codierung zu GRUPPDATEN]I: Ausführung zu GRUPPDATEN]: 
100 REM ======PROGRAMM GRUPPDATEN1 

110 REM *** ERSTER SATZ Krkkkkickickickxk AUFTRAG, MENGE? 221,10 
120 INPUT "AUFTRAG, MENGE? ";A2,M AUFTRAG, MENGE? 221,35 
130 LET Al = A2 AUFTRAG, MENGE? 221,14 
140 REM **%* GLEICHE GRUPPE *rrx#xx&xx% AUFTRAG, MENGE? 229,3 
150 IF A2< > Al THEN 200 221 MIT GRUPPENSUMME 59 
160 LET Sl =S1 +M AUFTRAG, MENGE? 230,70 
170 INPUT "AUFTRAG, MENGE? ";A2,M 229 MIT GRUPPENSUMME 3 
180 GOTO 150 AUFTRAG, MENGE? 230,55 
190 REM *%*%* GRUPPENWECHSEL FFrr#&rKKKr% AUFTRAG, MENGE? 0,0 

200 PRINT Al;'" MIT GRUPPENSUME '";S1 230 MIT GRUPPENSUMME 125 
210 IF A2 = O THEN PRINT "ENDE.": END ENDE. 


220 LET SI = 0: LET Al = A2: GOTO 150 


Im Programm GRUPPDATEN]I liegt ein einstufiger Gruppenwechsel 
vor. 

Daneben können Gruppenwechsel auch mehrstuf ig sein. 
Dazu dieses Beispiel: Es wird nicht nur nach Aufträgen glei- 
cher Nummer gruppiert (=Untergruppe), sondern zusätzlich noch 
nach Vertreternummern (=Hauptgruppe). Auch ein solcher Haupt- 
gruppenwechsel wird durch den Vergleich (V2<>3V1) bzw. '"Vertre- 
ter neu<> Vertreter alt' festgestellt. 


Verfahren des Suchens, Mischens, Sortierens und Gruppierens 
(Gruppenwechsel) von Daten werden häufig im Zusammenhang mit 
der Verarbeitung großer Datenbestände in Dateien bzw. 
Fi le s angewendet. 

Der Dateiverabei tung wenden wir uns nächsten 
Abschnitt 3.8 zu. 
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3.8 Dateiverarbeitung 


In Abschnitt 1.3.5 hatten wir vier Formen zur Organisation von 
Dateien bzw. Files erläutert: 


- sequentielle Datei (Zugriff in Speicherungsfolge) 
- Direktzugriff-Datei (Auf den Datensatz direkt) 

- Index-sequentielle Datei (Inhaltsverzeichnis als Index) 
- Verkettete Dateien (Zeiger weist auf andere Datei) 


In Abschnitt 3.8.1 demonstrieren wir die sequentielle Dateior- 
ganisation am Beispiel einer Telephon-Datei. Das Programm mit 
Namen TELEPHON-SEOQOI ist mit BASIC 2.0 programmiert, das dem 
"Commodore 64 BASIC V2'" entspricht. 


In Abschnitt 3.8.2 ändern wir das Programm zur Verwaltung der 
sequentiellen Telephon-Datei so ab, daß es in der Programmier- 
sprache BASIC 4.0 läuft. BASIC 4.0 als die Standardsprache 
der Commodore-Serien 4000 und 8000 läuft - über entsprechende 
Zusatz-Software - auch auf dem Commodore 64 . 


In Abschnitt 3.8.3 zeigen wir den Direktzugriff am Beispiel 
einer Artikeldatei. 


3.8.1 Sequentielle Datei mit BASIC 2.0 


Programm TELEPHON-SEQ]I verwaltet eine sequentielle Telephon- 
datei. Zur Orientierung sehen wir uns das wiedergegebene Aus- 
führungsbeispiel an. 


3.8.1.1 Menügesteuerte Dateiverwaltung 


Nach Eingabe von RUN wird ein Menü mit zehn Wahlmöglichkeiten 
gezeigt. Nach dem Eintippen von 1 als Menüwahl sowie TELDATEI 
als Dateiname wird diese (derzeit nur neun Einträge umfassen- 
de) Datei komplett in den Hauptspeicher geladen. Dann werden 3 
zusätzliche Einträge eingebenen (Menüwahl 4), der Eintrag von 
STROMANN geändert (Menüwahl 6), der Eintrag von RUMMEL aus der 
Datei gelöscht (Menüwahl 7), die verbliebenen elf Datensätze 
nach Namen sortiert (Menüwahl 9) und ausgegeben (Menüwahl 3). 
Abschließend werden die elf Telephoneinträge unter dem Namen 
TELDATEI auf Diskette abgespeichert. 


3.8.1.2 Dateiweiser Datenverkehr 


Die Datei wird komplett in den Hauptspeicher eingelesen (Menü- 
wahl 1), um sie dort in den Arrays N$() (für die Namen) sowie 
T$() (für die Telephonnummern) abzulegen und zu verarbeiten 
(Menüwahl 3-9). Abschließend werden alle Einträge komplett Da- 
tensatz für Datensatz auf Diskette als externe Datei abgespei- 
chert (Menüwahl 2). Der Datentransport zwischen Externspeicher 
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(Diskette) und Internspeicher (Hauptspeicher) erfaßt immer die 
ganze Datei als Einheit. Der sequentielle Dateizugriff erfolgt 
somit allein bei Menüwahl 1 und 2. Da er einmalig die komplet- 
te Datei umfaßt, spricht man vom dateiweisen Da- 
tenverkehr. Dem Vorteil der bequemen, schnellen (da internen) 
Verarbeitung steht der Nachteil gegenüber, daß die Datei grös- 
senmäßig durch den Hauptspeicherplatz begrenzt ist. 

Die Direktzugriff-Datei in Abschnitt 3.8.3 demonstriert den 
datensat z we i sen Datenverkehr als Gegenstück zum 
dateiweisen Datenverkehr. 


Ausführung zur Verwaltung einer Telephondatei über 
Programm TELEPHON-SEO1: 


RUN 
TELEPHONLISTE ALS SEQUENTIELLE DATEI. 


MENUE ZUR VERWALTUNG DER TELEPHON-DATEI 


0 BEENDEN Ein Hinweis: 

LADEN DER DATEI -> INTERN Das Menü wird wiederholt 
2 SPEICHERN DER DATEI -> EXTERN ausgegeben: jeweils nach 
3 DRUCKEN GESAMTVERZEICHNIS dem Eintippen von 
4 EINGEBEN VON EINTRAEGEN WEITER MIT RETURN. 
5 SUCHEN EINES EINTRAGS 
6 AENDERN EINES EINTRAGS In der vorliegenden Aus- 
7 LOESCHEN EINES EINTRAGS führung wird (aus Platz- 
8 EINFUEGEN EINES EINTRAGS gründen) nur die erste 
9 SORTIEREN DER GESAMTDATEI Menü-Ausgabe wiedergegeben. 

WAHL 0-9: 1 


NAME DER DATEI: TELDATEI 

9 EINTRAEGE TELDATEI --> HAUPTSPEICHER. 
WEITER MIT RETURN 

MENUE ZUR VERWALTUNG DER TELEPHON-DATEI 


WAHL 0-9: 3 

NAME: TELEPHONNUMMER: 
STROMANN 06262/3332 
WEBER 0721/1300165 
TREIBER 0611/232323 
KOEPFLE 06221/44421 
SCHOENFELDER 06203/5541 
SCHMIDTBORN 06221/332000 
RUMMEL 089/4413998 
MAUCHER 06204/1210 
RUDOLFS 06221/33125 


DATEIENDE NACH 9 EINTRAEGEN. 

WEITER MIT RETURN 

MENUE ZUR VERWALTUNG DER TELEPHON-DATEI 
WAHL 0-9: 4 

NAME (O=ENDE): DOMBERG 
TELEPHONNUMMER: 07622/163390 

NAME (O=ENDE): HOFFMANN 
TELEPHONNUMMER: 0621/1199110 
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Fortsetzung der Ausführung zu Programm TELEPHON-SEQ]: 


NAME (O=ENDE): KRAEMER 

TELEPHONNUMMER: 06227/1971 

NAME (O=ENDE): O 

WEITER MIT RETURN 

MENUE ZUR VERWALTUNG DER TELEPHON-DATEI 
WAHL 0-9: 6 

NAME DES ZU AENDERNDEN EINTRAGS: STROMANN 
STROMANN AENDERN IN: ?STROMANN-KRAEMER 
06262/3332 AENDERN IN:: ?06262/3332 
STROMANN-KRAEMER 06262/3332 KORREKT (JA/NEIN): ?JA 
WEITER MIT RETURN 

MENUE ZUR VERWALTUNG DER TELEPHON-DATEI 
WAHL 0-9: 7 

NAME DES ZU LOESCHENDEN EINTRAGS: RUMMEL 
RUMMEL TATSAECHLICH LOESCHEN (JA/NEIN): ?JA 
WEITER MIT RETURN 

MENUE ZUR VERWALTUNG DER TELEPHON-DATEI 


WAHL 0-9: 9 


SORTIEREN VON 11 DATENSAETZEN DER DATEI TELDATEI BEGINNT. 
SORTIEREN IM HAUPTSPEICHER BEENDET. 
WEITER MIT RETURN 


MENUE ZUR VERWALTUNG DER TELEPHON-DATEI 


WAHL 0-9: 3 

NAME: TELEPHONNUMMER: 
DOMBERG 07622/163390 
HOFFMANN 0621/1199110 
KOEPFLE 06221/44421 
KRAEMER 06227/1971 
MAUCHER 06204/1210 
RUDOLFS 06221/33125 
SCHMIDTBORN 06221/332000 
SCHOENFELDER 06203/5541 
STROMANN-KRAEMER 06262/3332 
TREIBER 0611/232323 
WEITER BLAETTERN 

WEBER 0721/1300165 


DATEIENDE NACH 11 EINTRAEGEN. 
WEITER MIT RETURN 
MENUE ZUR VERWALTUNG DER TELEPHON-DATEI 


WAHL 0-9: 2 

NAME DER AUSGABEDATEI: TELDATEI 
BISHERIGE DATEI ZERSTOEREN (JA/NEIN): JA 
11 EINTRAEGE HAUPTSPEICHER --> TELDATEI 
WEITER MIT RETURN 


MENUE ZUR VERWALTUNG DER TELEPHON-DATEI 
WAHL 0-9: 0 
PROGRAMMENDE. 
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3.8.1.3 Datei öffnen, verarbeiten und schließen 


Zum Steuerprogramm in den Zeilen 240-300: Wie auch das Struk- 
togramm zu TELEPHON-SEQ1 zeigt, besteht das Programm aus einer 
Wiederholungsstruktur (Schleife), in die eine Auswahlstruktur 
(Fallabfrage in Zeile 270) eingeschachtelt ist. 


Zum Unterprogramm LADEN in den 1000er Zeilen: Hier erkennt man 
den für die Dateiverarbeitung typischen 3er-Schritt (vgl. Ab- 
schnitt 1.3.5.4) "Öffnen - Verarbeiten - Schließen': 


1. Datei öffnen: In 1030 die Datei unter dem in F$ abgelegten 

Namen auf Kanal 2 eröffnen. 

1030 OPEN 2,8,3," 0:"+F$+",S,R" 
Kanalnummer 2 
Gerätenummer 8 (Diskette) 
Sekundäradresse 3 
Diskettenlaufwerk 0 
Dateiname in F$ 
+ verknüpft Strings 
S für Sequentielle Datei 
R für Read (Lesen) 

Auf den mit 1000 OPEN1,8,15 eröffneten Fehlerkanal 1 gehen 

wir in Abschnitt 3.8.1.5 ein. 


2. Datei verarbeiten: In 1050-1070 alle 2-Komponenten-Sätze 
der Datei nach N$() und T$() einlesen. Der erste Dateiein- 
trag ist die Satzanzahl N. 

1050 INPUT #2,N 
Über Kanal 2 den ersten 
| Eintrag nach N lesen 

3. Datei schließen: In 1080 wird die Datei mit CLOSE 2 un- 
verändert geschlossen (es wurde ja nur gelesen). 


Zum Unterprogramm SPEICHERN in den 2000er Zeilen: Als erstes 
wird die Satzanzahl N auf die Datei geschrieben, dann die N 
Datensätze jeweils mit den zwei Datenfeldern Name und Tele- 
phonnummer. 

In der OPEN-Anweisung in Zeile 2050 steht nun anstelle von "R" 
für Read (Lesen) der Parameter "Ww" für Write (Schreiben). An- 
stelle der Leseanweisung INPUT #2 verwenden wir die Schreib- 
anweisung PRINT #2. Da die Einträge in der Datei durch RETURN 
bzw. CHR$(13) getrennt gespeichert sind, müssen wir die Tren- 
nungszeichen über PRINT #2 auch schreiben: 


1060 INPUT #2,N$(I),T$(I) Alle Zeichen bis zum nächsten RE- 
TURN nach N$(I) lesen und die Zei- 
che bis zum dann folgenden RETURN 
nach T$(I) lesen. 

2080 PRINT #2,N$(I) : PRINT #2,T$(I) N$(I) speichern, dann 
RETURN, dann T$(I) und dann erneut 
RETURN speichern. 

2080 PRINT #2,N$(I),CHR$(13),T$(I) Zweite Form. 

2080 PRINT #2,N$(I);CHR$(13);T$(I);CHR$(13) Dritte Form. 

Bei allen drei Formen der Anweisung 280 PRINT #2 werden die 
Datenfelder jeweils durch CHR$(13) bzw. RETURN getrennt. 
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Codierung zu Programm TELEPHON-SEQ1: 


100 REM ======PROGRAMM TELEPHON-SEQ1 

110 PRINT "TELEPHONLISTE ALS SEQUENTIELLE DATEI.": PRINT 

120 : 

130 REM ======VEREINBARUNGSTEIL 

140 DIM N$(100): REM 100-ELEMENTE-FELD FUER NAMEN 

150 DIM T$(100): REM 100-ELEMENTE-FELD FUER TELEPHONNUMMERN 


160 REM W, W$: INTEGER BZW. TEXT (MENUEWAHL) 

170 REM F$: NAME DER SEQUENTIELLEN TELEPHON-DATEI 
180 REM N: INTEGER (ANZAHL VON SAETZEN IN DER DATEI) 
190 REM I, Z: INTEGER (LAUFVARIABLEN) 

200 REM F: INTEGER (FLAGGE BZW. FLAG) 


210 REM HINWEIS: DATEI-ANWEISUNGEN IN COMMODORE-BASIC 2.0 
220 : 

230 REM ======ANWEISUNGSTEIL 

240 GOSUB 500: REM UNTERPROGRAMM MENUEANGEBOT 

250 IF W = O THEN PRINT "PROGRAMMENDE.": END 

260 PRINT CHR$ (147); 

270 ON W GOSUB 1000, 2000, 3000,4000, 5000, 6000, 7000, 8000, 9000 
280 PRINT "WEITER MIT RETURN" 


290 GET W$: IF W$ = "" THEN GOTO 290 
300 PRINT CHR$ (147);: GOTO 240 
310 : 


320 REM ***UNTERPROGRAMM MENUEANGEBOT*#**3kk3ckakskaksickikkieiakskickk 
500 PRINT "MENUE ZUR VERWALTUNG DER TELEPHON-DATEI" 


510 PRINT "--------------- - -- - " 
520 PRINT" O BEENDEN" 

530 PRINT " 1 LADEN DER DATEI -> INTERN" 
540 PRINT" 2 SPEICHERN DER DATEI -> EXTERN" 
550 PRINT" 3 DRUCKEN GESAMTVERZEICHNIS" 
560 PRINT" 4 EINGEBEN VON EINTRAEGEN" 

570 PRINT" 5 SUCHEN EINES EINTRAGS" 

580 PRINT " 6 AENDERN EINES EINTRAGS" 

590 PRINT" 7 LOESCHEN EINES EINTRAGS" 

600 PRINT " 8 EINFUEGEN EINES EINTRAGS" 

610 PRINT " 9 SORTIEREN DER GESAMTDATEI" 

620 PRINT "-------------------------------_ " 
630 INPUT "WAHL 0-9: ";W$: LETW = VAL (W$) 


640 IFWX<DOORW > 9 THEN PRINT "ZWISCHEN O UND 9.'": GOTO 630 
650 IFW< > INT (W) THEN PRINT "GANZZAHLIG.": GOTO 630 

660 RETURN 

670 : | 

680 REM *%**UNTERPROGRAMM LADEN * kr 3kakakakaktatsksisiiakikikikiinksininkukikikiiniafaiekikck 
1000 OPEN1,8,15, "10" 

1010 GOSUB 1500 

1020 INPUT "NAME DER DATEI";F$ 

1030 OPEN2,8,3,"0:" + F$ + ",S,R" 

1040 GOSUB 1500 

1050 INPUT #2,N 

1060 FOR I = 1 TO N: INPUT #2,N$(I),T$(I): NEXT I 

1070 PRINT N;" EINTRAEGE ";F$;" --> HAUPTSPEICHER." 

1080 CLOSE2:CLOSE1 

1090 RETURN 

1100 : 
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Codierung zu Programm TELEPHON-SEQ1I (erste Fortsetzung): 


1500 
1510 
1520 
1530 
1540 
1550 
1560 
2000 
2010 
2020 
2030 
2040 
2050 
2060 
2070 
2080 
2090 
2100 
2110 


2120 : 


2130 
3000 
3010 
3020 
3030 
3040 
3050 
3060 
3070 


REM °***FEHLER DISK I/O:ktaeokk 

INPUT #1,EN,EM$,ET,ES 

IF EN = O THEN RETURN 

PRINT "FEHLER DISK 1/0: ";EN;5EM$;ET;ES 


CLOSE2: STOP 


"REM *%**UNTERPROGRAMM SPEICHERN. ?*3#3k>kakaakaeakakakakakakakskaksiofakakakaksisfaksiaksksiakakik 


OPEN1,8,15,'"'I0O": REM FEHLERKANAL 


GOSUB 1500: REM FEHLERABFRAGE 

INPUT "NAME DER AUSGABEDATEI";F$ 

INPUT "BISHERIGE DATEI ZERSTOEREN (JA/NEIN):";W$ 
IF W$ < > "JA" THEN 2110 


OPEN2,8,3," 0:" + F$ + ",S,W" 


GOSUB 1500: REM FEHLERABFRAGE 

PRINT #2,N: REM ANZAHL DER EINTRAEGE 

FOR I = 1 TO N: PRINT #2,N$(I): PRINT #2,T$(I): NEXT I 
PRINT N;'' EINTRAEGE HAUPTSPEICHER --> ";F$ 


CLOSE2:CLOSEI1 


RETURN 


REM _ ®skUNTERPROGRAMM DRUCKEN 3*>k3k3teieakeaiesiesfafeaieafesfeaieafesfafeakeakakaeakcakafcak 
PRINT "NAME: TELEPHONNUMMER: " 

PRINT "-------------- - - -- - - - " 

FOR I = 1 TON 

PRINT N$(I); TAB( 24);T$(I) 

IF INT (I / 10) < > I / 10 THEN 3060 

INPUT "WEITER BLAETTERN '";W$ 

NEXT I 

PRINT "DATEIENDE NACH ";N;'" EINTRAEGEN.": RETURN 


3080 : 


3090 
4000 
4010 
4020 
4030 


REM skUNTERPROGRAMM EINGEBEN >*>k3k3k>kakakeakkakeakesieskakeakakakakakakakakakakakakakakakakakicr 


LETN=N+]1l 

INPUT "NAME (O=ENDE): ";N$(N) 

IF N$(N) = "0" THEN LETN = N - 1: RETURN 
INPUT "TELEPHONNUMMER: ";T$(N): GOTO 4000 


4040 : 


4050 
5000 
5010 
5020 
5030 
5040 
5050 
5060 
5070 
5080 


REM BiokUNTERPROGRAMM SUCHEN ?>*3*>k3kakakakakakakakakakakskakakakakakgfgiaksfakaksiakakskakaksiaknk 


INPUT "ZU SUCHENDER NAME: ";W$ 

LET F = O: REM FLAGGE GESENKT 

FOR I=1TON 

IF LEFT$ (N$(I), LEN (W$)) < > W$ THEN 5060 
PRINT "GEFUNDENE NUMMER: ";T$(I) 

LETI=N: LETF= -1 

NEXT I 

IF NOT F THEN PRINT W$;" NICHT GEFUNDEN." 
RETURN 


5090 : 


5100 
6000 
6010 
6020 
6030 
6040 
6050 
6060 
6070 
6080 
6090 
6100 


REM sk UUNTERPROGRAMM AENDERN 3x 3kakeakeeateaieafeofeafeaieafaeafeajeafafeafeaieafseafeafafseakeakcakskakakfcak 


INPUT "NAME DES ZU AENDERNDEN EINTRAGS: ";w$: LET F= O0 
FOR I = 1 TON 

IF LEFT$ (N$(I), LEN (W$)) < > W$ THEN 6080 

PRINT N$(I);'" AENDERN IN: ";: INPUT N$(I) 

PRINT T$(I);" AENDERN IN: ";: INPUT T$(I) 

PRINT N$(I);" ";T$CI);" KORREKT (JA/NEIN): ";: INPUT W$ 
IF W$ < > "JA" THEN 6030 

LETI=N:LETF= -1 

NEXT I 

IF NOT F THEN PRINT "EINTRAG ";W$;'" NICHT GEFUNDEN." 
RETURN 
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Codierung zu Programm TELEPHON-SEQ1I (zweite Fortsetzung): 


6110 : 

6120 REM *%**UNTERPROGRAMM PHYSISCH LOESCHEN *33kakakakaiakakskkaksikakaikskakaickaikikik 
6221 / 99991 

7000 INPUT "NAME DES ZU LOESCHENDEN EINTRAGS: ";W$: LETF= O0 

7010 FOR I = 1TON 

7020 IF LEFT$ (N$(I), LEN (W$)) < > W$ THEN 7100 

7030 PRINT N$(I);'" TATSAECHLICH LOESCHEN (JA/NEIN): ";: INPUT W$ 

7040 IF W$ < > "JA" THEN 7090 

7050 FOR Z=ITON-1 

7060 LET N$(Z) = N$(Z + 1): LET T$(Z) = T$(Z + 1) 


7070 NEXT Z 

7080 LETN=N-]1 

7090 LETI=N: LETF= -]1 
7100 NEXT I 


7110 IF NOT F THEN PRINT W$;'" NICHT GEFUNDEN. KEIN LOESCHEN MOEGLICH." 
7120 RETURN 

7130 : 

7140 REM *%* UNTERPROGRAMM EINFUEGEN tk xk3akikkakstaksaiakskiiaiakikiiniakskiieickakickckk 
8000 PRINT "DATEI ";F$;'" HAT ";N;'" EINTRAEGE. NACH WELCHEM" 

8010 INPUT "EINTRAG EINFUEGEN (SATZNUMMER TIPPEN): ";W 

80220 LETN=N+]1 

8030 FOR Z = N TOW + 2 STEP -1 

8040 LET N$(Z) = N$(Z - 1): LET T$(Z) = T$(Z - 1) 

8050 NEXT Z 

8060 PRINT '"NACHFOLGENDE EINTRAEGE SIND VERSCHOBEN ." 

8070 INPUT "EINZUFUEGENDER NAME: ";N$(W + 1) 

8080 INPUT "EINZUFUEGENDE NUMMER: ";T$(W + 1): GOTO 280 

8090 : 

8100 REM *** UNTERPROGRAMM SORTIEREN-DURCH-AUSTAUSCH-NACH-AUSWAHL FrHrH** 
9000 PRINT "SORTIEREN VON ";N;'" DATENSAETZEN DER DATEI ";F$;" BEGINNT." 
9010 FOR I=1TON-1 

9020 LET MINSTELL = I:NAMMIN$ = N$(I):TELMIN$ = T$(I) 

9030 : FOR Z = (I + 1) TON TELMIN$ = T$(Z) 
9040 :: IF (N$(Z) < NAMMIN$) THEN LET MINSTELL = Z:NAMMIN$ = N$(Z): 

9050 : NEXT Z 

9060 : LET N$(MINSTELL) = N$(I):N$CI) = NAMMIN$:T$(MINSTELL) = T$(I): 
9070 NEXT I T$(I) = TELMIN$ 
9080 PRINT "SORTIEREN IM HAUPTSPEICHER BEENDET.": RETURN 


3.8.1.4 Verarbeitung von Arrays in Unterprogrammen 


Zum Unterprogramm SUCHEN in den 5000er Zeilen: Hier wird rein 
sequentiell gesucht. Die Zählerschleife hat nur einen Ausgang. 
Flagge F dient der Ablaufsteuerung. 


Zum Unterprogramm PHYSISCH LÖSCHEN in den 7000er Zeilen: Phy- 
sisch löschen bedeutet tatsächlich löschen. Die Zählerschleife 
7050-7070 bewirkt, daß alle Einträge ab dem zu löschenden Ein- 
trag um eine Position bzw. um ein Element in den Arrays N$() 
und T$() vorgerückt werden. 
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Zum Unterprogramm EINFÜGEN in den 8000er Zeilen: Die Zähler- 
schleife 8030 FOR Z=N TO W+2 STEP -1 rückt vom letzten Satz N 
ausgehend Einträge um jeweils eine Position nach hinten, umin 
Zeile 8070-8080 den neuen Eintrag einzufügen. 
Zum Unterprogramm SORTIEREN in den 9000er Zeilen: Wie in Pro- 
gramm SORTDATENI (vgl. Abschnitt 3.7.3.1) wird das "Sortieren 
durch Austausch nach Auswahl" verwendet, jedoch mit folgenden 
Abweichungen: 1) Anstelle von Zahlen werden Strings sortiert. 
2) Die Anzahl der Sortierbegriffe ist variabel. 





Dateiweiser Datenverkehr: Gesamtdatei intern in Arrays ablegen 


3.8.1.5 Fehlerbehandlung beim Dateizugriff 


Die Abfrage der Floppy nach Fehlermeldungen vollzieht sich in 

einem 3er-Schritt: 

- Mit 1000 OPEN 1,8,15 unter der Sekundäradresse 15 den Ka- 
nal 1 als Fehlerkanal zur Floppy mit Gerätenummer 8 Öffnen. 

- Nach jedem Datei- bzw. Diskettenzugriff mit GOSUB 1500 ein 
Unterprogramm aufrufen und mit 1510 INPUT#1,EN,EM$,ET,ES 
die vom DOS automatisch bereitgestellte Fehlerinterpretation 
in die vier Variablen EN (Fehlernummer, Error Number), EM$ 
(Fehlermeldung, Error Message), ET (Spurnummer, Error Track) 
sowie ES (Sektornummer, Error Sector) einlesen. Dazu können 
wir auch andere Variablennamen wählen. Für EN=0 erfolgte ein 
fehlerfreier Diskettenzugriff. Für EN<>0 wird die Fehlerin- 
terpretation ausgegeben und der Programmlauf gestoppt. 

- Mit 1080 CLOSE 1 wird der Befehlskanal wieder geschlossen. 

Im folgenden Abschnitt 3.8.2 werden wir sehen, daß die Feh- 

lerbehandlung in BASIC 4.0 einfacher durchzuführen ist als 

in BASIC 2.0. 
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Struktogramm zu Programm TELEPHON-SEQ1: 


Arrays N$() und T$ für Namen und Nummern dimensionieren 


Solange Menüwahl W ungleich O0 ist, wiederhole 





Menü anbieten und gültige Menüwahl in W speichern 


Fallabfrage zu W 


L 
ö 
Ss 
c 
h 
e 
n 


SHOP T7TArPTO N 
SvTva>srkbG 
SvWo chm>5SHr&9 

SO DROtHrrRrROoOUun 


Wartepunkt: Weiter mit RETURN 


3.8.1.6 Speicherung der Datei im Hauptspeicher 


Es gibt mehrere Möglichkeiten, eine Datei bzw. deren Datenfel- 
der im RAM bzw. Hauptspeicher zu speichern. 


1) 


2) 


3) 


4) 


Jedes Datenfeld erhält einen eigenen String zugewiesen. 

100 Sätze zu je 2 Feldern beanspruchen 100%*2*5=1000 Bytes 
allein zur Speicherorganisation (5 Bytes je Variable). Die- 
se Lösung ist nicht ökonomisch. 

E in String für die gesamte Datei. Dies ist 

kaum möglich, da ein String maximal 255 Zeichen lang sein 
kann. 

Ein String mit fester (konstanter) Länge für jeden Satz: 
Das längste Feld der Datei bestimmt die für jedes Feld im 
String zu reservierende Stellenzahl. Dies führt leicht zur 
Verschwendung von Speicherplatz. 

Ein String mit variabler Länge für jeden Satz: 

Zwischen den Feldern stehen Trennungszeichen (z.B. ‚,). Da- 
mit ergibt sich eine gute Speicherausnutzung. 


Bei den Möglichkeiten 1), 3) und 4) wird man die Strings meist 


in 


einem Array anordnen. 
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3.8.2 Sequentielle Datei mit BASIC 4.0 


Das Programm TELEPHON-SEQ2 läuft genauso ab wie das Programm 
TELEPHON-SEQ1, die Listings dagegen unterscheiden sich in den 
Unterprogrammen LADEN (1000er Zeilen) sowie SPEICHERN (2000er 
Zeilen). Warum? Programm TELEPHON-SEQ2 benutzt die Disketten- 
befehle von BASIC 4.0 anstelle von der von BASIC 2.0. 


Folgende BASIC 4.0-Anweisungen werden verwendet: 


- 1010 DOPEN#2,(F$),DO 
Als logische Datei 2 in Laufwerk DO wird eine Telephondatei 
eröffnet, deren Dateiname TELDATEI in F$ gespeichert ist. 
F$ wird als Eingabedatei zum Lesen eröffnet. 


- 1020 IF DS<>0O THEN PRINT "FEHLER: ";DS$ : STOP 
Statusvariablen DS bzw. DS$ abfragen. Die Fehlerbehandlung 
sollte nach jedem Diskettenzugriff durchgeführt werden. 
STOP meldet die Zeile, in der der Fehler entstanden ist. 


Codierung der Unterprogramme LADEN und SPEICHERN von Programm 
TELEPHON-SEQ2 in BASIC 4.0 (alle anderen Zeilen stimmen mit 
Programm TELEPHON-SEQ1 genau überein): 


9099 REM *** UNTERPROGRAMM LADEN Brakel KRITIK 


1000 INPUT "NAME DER DATEI"; F$ 

1010 DOPEN#2,(F$),DO 

1020 IF DS<>O THEN PRINT "FEHLER BEIM OEFFNEN: ";DS$: STOP 
1030 INPUT#2,N 

1040 IF DS<>O THEN PRINT "LESEFEHLER ANZAHL: ";DS$ : STOP 
1050 FOR I=1 TO N: INPUT#2,N$(I),T$(I) 

1060 IF DS<>O THEN PRINT "LESEFEHLER: ";DS$ : STOP 

1070 PRINT N;" EINTRAEGE ";F$;'" --> HAUPTSPEICHER." 

1080 DCLOSE#2 

1090 RETURN 

1100 : 

1110 REM ***UNTERPROGRAMM SPEICHERN *k3toksckzkasioksicksksioksiekikskikiickk 
2000 INPUT "NAME DER AUSGABEDATEI"; F$ 

2010 INPUT "BISHERIGE DATEI ZERSTOEREN (JA/NEIN)'"; W$ 

2020 IF W$<>"'JA" THEN 2140 

2030 SCRATCH DO, (F$) 

2040 DOPEN#2,(F$),W,DO 

2050 IF DS<>O THEN PRINT "FEHLER BEIM OEFFNEN: ";DS$ : STOP 
2060 PRINT#2,N 

2070 IF DS<>O THEN PRINT "FEHLER SCHREIBEN ANZAHL: ";DS$ : STOP 
2080 FOR I-1 TON 

2090 PRINT#2,N$(I),CHR$(13),T$(I) 

2100 IF DS<>O THEN PRINT "SCHREIBFEHLER: ";DS$ : STOP 

2110 NEXT I 

2120 PRINT N;" EINTRAEGE HAUPTSPEICHER --> ";F$ 

2130 DCLOSE#2 

2140 RETURN 

2150 : 
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- 2040 DOPEN#2,(F$),W,DO 
Sequentielle Datei als Ausgabedatei zum Schreiben Öffnen. 
Parameter "W" für Write. 


- 2030 SCRATCH DO,(F$) 
Datei namens F$ in Laufwerk DO zerstoeren. 
SCRATCH hier nicht unbedingt erforderlich, da Parameter "w" 
in Zeile 2040 ein Schreiben von Dateia n f an g an bewirkt, 


- 2090 PRINT#2,N$(I),CHR$(13),T$(I) 
Schreibanweisung in BASIC 4.0 und BASIC 2.0 gleich: CHR$(13) 
bzw. RETURN als Trennungszeichen zwischen den Datenfeldern. 
Hinweis: Hinter Datenfeld T$(I) wird automatisch ein RETURN 
gesendet (PRINT X sendet RETURN, PRINT X; dagegen nicht). 


- DCLOSE#2 
Datei 2 wieder schließen. 


Das "D" am Anfang von DOPEN und DCLOSE steht für Diskette. 


3.8.3 Direktzugriff-Datei mit BASIC 4.0 


Die Programme ART-DIRSCHREIBI und ART-DIRLES]I dienen Zur Ver- 
waltung einer Artikeldatei, die als Direktzugriff-Datei bzw. 
relative Datei organisiert ist. 

Gegenüber der Telephondatei (Abschnitte 3.8.1 und 3.8.2) weist 
diese Artikeldatei folgende Neuerungen auf: 

- Datensätze mit konstanter Satzlänge . 

- Direkt zugriff über einen Satzzeiger S (RECORD#,(S)). 

- Satzweiser Datenverkehr, kein dateiweiser Datenverkehr.hr. 

- Direkte Adressierung des Datensatzes. 

- Bequeme Programmierung in BASIC 4.0 . 

Diese Punkte wollen wir nun im einzelnen erläutern. 


3.8.3.1 Datei mit konstanter Datensatzlänge 
Die Datensätze der Artikeldatei namens ARTIKELDATEI haben alle 


eine feste Satzlänge von L=36 Stellen und bestehen aus jeweils 
vier Datenfeldern. Jeder Satz ist demnach gleich lang. 


Inhalt: Artikelnummer: Bezeichnung: Menge: Stückpreis: 
Stellen: / 4 / 20 Pt 2a / 8 / 
(DATENTYP) STRING STRING STRING STRING 
Var.-Name: A$(1) A$(2) A$(3) A$(4 


Beispiel: 


Datensatz-Beschreibung (36 Stellen) für die ARTIKELDATEI 
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Eine Direktzugriff-Datei hat im Gegensatz zur sequentiellen 
Datei stets eine feste Datensatzlänge_ 
die in der DOPEN-Anweisung angegeben werden muß: 


190 DOPEN#1 ,"ARTIKELDATEI",L36,DO 
Kanalnummer 1 
Dateiname 
Datensatzlänge fest 
Laufwerknummer (0 


Gibt man die Parameter als Variable ein, so lautet die DOPEN- 
Anweisung z.B. so: 

190 DOPEN#(KN),(F$),L(SL),D(LN) 
Eine einmal für die Datei namens ARTIKELDATEI angegebene Satz- 
nummer von 36 Stellen kann nicht mehr verändert werden und muß 
bei jedem späteren Dateizugriff angegeben werden (eine andere 
Länge ergibt eine Fehlermeldung). 
Das Lesen und Schreiben von Sätzen kann in beliebiger Reihen- 
folge geschehen, d.h. wir können zuerst den 51. Satz schreiben 
(Satzbeginn ab Stelle 50%36=-1800) und dann erst den 2. Satz 
(Satzbeginn ab Stelle 1%36-36). Über die feste Satzlänge er- 
mittelt das Betriebssystem die Stelle (relativ zum Dateianfang 
gesehen), an welcher der Satz beginnt; der oft verwendete Be- 
griff der relativen Dat e i weist darauf hin. In 
der Directory steht die ARTIKELDATEI als REL (für RELative Da- 
tei). Kurz: Es liegt eine REL-Datei vor. 


In Commodore-BASIC werden leere Datensätze durch das Zeichen 
CHR$(255) markiert. V o r dem Arbeiten empfiehlt es sich, eine 
Leerdat ei mit der ungefähr benötigten Anzahl von Da- 
tensätzen anzulegen. Eine einfache Möglichkeit hierzu besteht 
darin, an die Stelle des letzten Satzes das Zeichen CHR$(255) 
zu schreiben. Alle vorangehenden CHR$(255) fügt das DOS dann 
selbst ein. 

Für unsere ARTIKELDATEI erhalten wir bei einer Satzanzahl von 
40 folgenden Ablauf zum Anlegen einer Leerdatei: 


100 REM ======PROGRAMM ART-DIRANLEGI 
110 DOPEN#1 ,'"ARTIKELDATEI",L36,DO 
120 RECORD#1,(40) 

130 PRINT#1,CHR$(255) 

140 DCLOSE#1 


3.8.3.2 Direktzugriff über einen Satzzeiger 


Die RECORD#-Anweisung RECORD#1,(S) positioniert den Satzzei- 
ger S auf den gewünschten Datensatz, um ihn mittels PRINT# zu 
beschreiben bzw. mittels INPUT#1 zu lesen. 


In Programm ART-DIRANLEG1 zeigt RECORD#1,(40) auf den 40. Da- 
tensatz. 
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Struktogramm zum Schreibprogramm ART-DIRSCHREIBI1: 


Adreßrechnung: Satznummer S = Artikelnummer - 1000 


ARTIKELDATEI erweitert wieder schließen 







Im Struktogramm wird deutlich, daß sich das Schreiben von Da- 
tensätzen in die Datei über eine Ausgabeschleife mit der En- 
deabfrage A$(1)="0" vollzieht. 

Die untenstehende BASIC-Codierung zeigt, daß nach jedem 
Dateizugriff eine Fehlerabfrage (DS®©0) programmiert wird. Im 
Gegensatz zu BASIC 2.0 stehen uns in BASIC 4.0 dabei die Vari- 
ablen DS und DS$ zur Verfügung. 


Codierung zu Programm ART-DIRSCHREIB]I: 


199 REM ======PROGRAMM ART-DIRSCHREIEI 
11@ PRINT "SRETZE DIREKT SCHREIBEN. " 
129 : 

139 REM ======VEREINBARUNGSTEIL 


i4@ DIM Atcd4>: REM AETIEELSATZ MIT 4 DATEHFELDERN 
150 REM ARTIEELDATEI: TIREKTZUGRIFF-DATEI 
169 REM 5: RELATIVE SATZHUMMER 


170 REM 5=Al-1a08 : ADRESSRECHNUHNG 
120: 
136 REM ======ANWEISUNGSTEIL 


298 REM #1. DATEI ÜEFFNENSRRFRSSSSRIele 
218 DOPEN#1. "ARTIKELDATEI".L35. 08 

z29 IF DS<>B THEN PRINT "FEHLER OEFFNEN:";DS#: STOR 
229 REM #k2. SRETZE SCHREIBENBRRBSRESESEBIEIII 
248 PRINT "SAETZE SCHREIBEN (G=ENDEN, " 

258 FRINT "HUMMER. BEZ... BESTAND. FREIS:" 

258 INPUT A&C1). Asia). AFCa). As) 

27a IF A$ci)="g" THEN 246 

230 LET 5 = WALSASCIIS-1A0G : REM ADRESSRECHNUNG 

236 RECORD#1.5> : REM SATZZEIGER AUF SATZ 3 STELLEN 
209 FRINT#1.A$C1>;CHR$L44N SAFE) CHRECIHHSASCHHSCHRSCANI SARAH) 
31a IF DS<>& THEN PRINT "SCHREIBFEHLER:";DS$ : STOP 
229 GOTO 258 

230 REM ##*3. DATEI SCHLIESSENRERRRSRKSERE 
2489 DOLOSE#1 

358 PRINT "AUSGABEDATEI GESCHLOSSEN. ": END 
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Struktogramm zum Leseprogramm ART-DIRLES1: 


ARTIKELDATEI eröffnen als Direktzugriff-Datei mit Laenge 36 


Zu suchende Artikelnummer SUCH eintippen 
Wenn SUCH=0 dann Ende 


Adreßrechnung durchführen: S = SUCH - 1000 
Artikelsatz mit Satznummer S direkt lesen 


I Satz gefunden? 
Satzkomponenten Fehlerhinweis 
A$(1)-A$(4) zeigen ausgeben 


ARTIKELDATEI unverändert wieder schließen 








Ein Hinweis zur Zeile 290 in der BASIC-Codierung: Das Zeichen 
CHR$(255) wird vom DOS als Kennzeichen für einen "leeren Satz' 
verwendet. 


Codierung zu Programm ART-DIRLES]I: 


Fock 
PR 


=] m [N Ja na Pott ii 


x 
„2 
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-r 
De 

| 
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ef 
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PRINT "SAETZE DIREKT LESEN." 


Zn 
ah 


REM ======\!EREINEARUNGSTEIL 

DIM Afid42! REM AETIEELSATZ MIT 4 DATEHFELDERN 
FEM AFTIKELDATEI: DIFEKTZUGRIFF-DATEI 

REM SZ. SUCH: SATZHUMMER. SUCHPEGRIFF 

REM 5=5LUCH-1eee : ADRESSRECHNLNG 


yo yon yo We 
a 


KR 
anche 


t 


REM ======AHWEISUNGSTEIL 

FEM ###1. DATEI GEFFNENEEEEEEEERREEREEEREREEER 
DOPFEN#1. "AETIEELDATEI".L3E 

IF DSc<Ha THEN FRINT "FEHLER OEFFHEN:"SDS#: STOP 
239 FEEM ###2. SRETZE DIREKT LESEHEEEEEEIEEEEE 
248 IMPUT "ZU SUCHENDER ARTIKEL (O=ENDE)": SUCH 

zog IF SUCH=E THEN STE 

LET 5 = SUCH-1D80 

RELORDHL. 022 

TIMFUT#1.AFCLI. ARE. ARD. Ad. 

IF D5=58 DE A&CL=CHRFI2ST> THEN 5358 

IF DS<>2@ THEN FRINT "LESEFEHLER:"DS# : STOP 
FEINT "ARTIEELNUMMER: ";R&C12 

FRINT "FEZEICHHNUNG: AFCE 

FEINT "BESTANDSMENGE: ";A$e3> 

FREINT "STUECKFREIS: ";Atld> : GOTO 240 

FREIHT "... HICHT GEFUNDEN." : GOTO 248 

FEM ###3. EINGABEDATEI SCHLIESSENEEREREISRETEEF 
DCoLOSEH1 

FEIHT "DATEI UNWERRENDEFT GESCHLOSSEN. ": END 
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Ausführung zu Programm ART-DIRSCHREIBI: 


SAETZE DIREKT SCHREIBEN. 
SAETZE SCHREIBEN (O=ENDE). 
NUMMER, BEZ., BESTAND, PREIS: 
? 1019, ERDBEERE,200,1.95 
NUMMER, BEZ., BESTAND, PREIS: 
? 1034,TOMATE,100,2.25 
NUMMER, BEZ., BESTAND, PREIS: 
? 1007,RETTICH,50,0.70 
NUMMER, BEZ., BESTAND, PREIS: 
? 0,0,0,0 
AUSGABEDATEI GESCHLOSSEN. 
READY. 


Ausführung Zu ART-DIRLES1: 


SAETZE DIREKT LESEN. 

ZU SUCHENDER ARTIKEL (O=ENDE)? 1007 
ARTIKELNUMMER: 1007 

BEZEICHNUNG: RETTICH 
BESTANDSMENGE: 50 

STUECKPREIS: 0.70 

ZU SUCHENDER ARTIKEL (O=ENDE)? 1025 
... NICHT GEFUNDEN." 

ZU SUCHENDER ARTIKEL (O=ENDE)? O 
DATEI UNVERAENDERT GESCHLOSSEN. 


Der Zusammenhang 

"Satznummer S ergibt sich aus Artikelnummer minus 1000" 

260 LET S=SUCH-1000 (im Leseprogramm) 

280 LET S=VAL(A$(1))-1000 (im Schreibprogramm) 
wird als Adreß rechnung bezeichnet. Diese Adreß- 
rechnung stellt einen umkehrbaren Zusammenhang zwischen der 
Artikelnummer als Ordnungsbegriff einerseits und der relativen 
Satznummer als Speicherort andererseits her; "umkehrbar", weil 
aus der Satznummer (z.B. 119. Satz) die zugehörige Artikelnum- 
mer abgeleitet werden kann (also 1119). Man bezeichnet diese 
umkehrbare Adreßrechnung als di rekt e Adressierung. 


Die Adreßrechnung muß vo r dem Dateizugriff vorgenommen wer- 
den, d.h. vor jeder PRINT#- oder INPUT#-Anweisung: 
- In Programm ART-DIRSCHREIBI bewirken die Anweisungen 
280 LET S=VAL(A$(1))-1000 
290 RECORD#1,(S), 
daß nach Berechnung der Satznummer S in Zeile 280 (für Arti- 
kelnummer A1=1019 z.B. wird S=19) der Datensatz als 19. Satz 
direkt in die ARTIKELDATEI geschrieben wird. 
- In Programm ART-DIRLES1I bewirkt die Anweisungsfolge 
260 LET S=SUCH-1000 
270 RECORD#1,(5) 
dementsprechend, daß nach Ermittlung der Satzadresse S aus 
dem Suchbegriff SUCH der S. Datensatz direkt gelesen wird. 
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In Programm ART-DIRSCHREIBI bewirken die Anweisungen 
290 RECORD#1,(S) A$(4) 
300 PRINT#1,A$(1);CHR$(44);A$(2);CHR$(44);A$(3);CHR$(44); 
daß die 4 Datenfelder Nummer A$(1), Bezeichnung A$(2), Menge 
A$(3) und Stückpreis A$(4) als S. Datensatz gespeichert werden 
(für S=25 wird also der 25. Satz geschrieben und für S=3 der 
3. Satz). Intern im RAM legen wir den Datensatz also in einem 
4-Elemente-Array namens A$() ab. 
Die Datenfelder trennen wir mittels Komma bzw. CHR$(44) von- 
einander. Als Trennungszeichen ist auch RETURN bzw. CHR$(13) 
möglich. 
Hinter der letzten Variablen (hier hinter A$(4)) schreibt die 
PRINT#-Anweisung automatisch ein RETURN. 


Im Programm ART-DIRLESI dienen die Anweisungen 

270 RECORD#1,(S) 

280 INPUT#1,A$(1),A$(2),A$(3),A$(4) 
dazu, die vier Datenfelder des S. Datensatzes in die genannten 
Variablen einzulesen 
Die INPUT#-Anweisung liest ab der 1. Stelle des S. Satzes alle 
zeichen bis zum nächsten Trennungszeichen und weist diese Zei- 
chen dann der jeweils genannten Variablen zu. 
Die Trennungszeichen (hier: CHR$(44) und CHR$(13)) sind in der 
Datei abgelegt und müssen hinter PRINT# deshalb nicht angege- 
ben werden. 


3.8.3.3 Datensatzweiser Datenverkehr 


Programm TELEPHON-SEQI hat im dateiweisen Datenverkehr zu Be- 
ginn die gesamte Datei in den Hauptspeicher eingelesen und in 
Arrays abgelegt. Bei der durch die Programme ART-DIRSCHREIBI 
und ART-DIRLESI angesprochenen ARTIKELDATEI wird jeweils un- 
mittelbar nach der Anforderung ein Satz geschrieben oder aber 
gelesen. Wir sprachen vom "datensatzweisen Datenverkehr" (Ab- 
schnitt 3.8.1.2). 

Die Artikeldatei kann somit jetzt größer sein als der verfüg- 
bare Hauptspeicherplatz, da zwischen dem externen und dem in- 
terne Speicher stets nur ein Datensatz transportiert wird. Wie 
zeigt sich der datensatzweise Datenverkehr in der Codierung? 
In jede m Programm findet sich mindestens eine Anweisung 
mit einem Dateizugriff (PRINT# oder INPUT#). 


3.8.3.4 Direkte Adressierung des Datensatzes 


Artikel 1019 ist als 19. Satz in der Artikeldatei gespeichert, 
Artikel 1001 als 1. Satz, Artikel 1034 als 34. Satz. Die zeit- 
liche Reihenfolge der Speicherung spielt keine Rolle. Solange 
z.B. für den "'dazwischengehörenden' Artikel 1007 kein Satz ge- 
speichert ist, bleibt der entsprechende Speicherplatz auf der 
Diskette eben leer - es entstehen L üc ken. Die schlechte 
Ausnutzung der Speicherplatzes ist sicher ein Nachteil der Di- 
rektzugriff-Datei. 
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3.8.3.5 Indirekte Adressierung des Datensatzes 


Das Adreßrechnungsverfahren der direkten Adressierung 
ist ungeeignet, wenn der Ordnungsbegriff einer Datei streut. 
Betrachten wir dazu als Beispiel eine Artikeldatei: 
Kleinste Artikelnummer 1, größte Artikelnummer 300000, total 
2000 Artikel im Sortiment, "SatzNr=ArtNr" als Adreßrechnung. 
Für die nur 2000 Artikel müssten 300000 Artikelsätze in der 
Datei bereitgestellt werden. 
Günstiger ist die indirekte Adressierung. Ein Bei- 
spiel für dieses Verfahren ist das Divisions-Rest-Verfahren. 
Allerdings kann das Problem entstehen, daß für zwei Ordnungs- 
begriffe dieselbe Satznummer berechnet wird; damit kommt es zu 
Doppelbelegungen bzw. Überläufern, die gesondert zu speichern 
sind. Im Zusammenhang mit der indirekten Adressierung spricht 
man auch von Ha sh ing ('Mischmasch') und vom Hash-Code. 





Zwei Adreßrechnungs-Arten: Direkte und indirekte Adressierung 


Die indirekte Adressierung ist auch stets dann angezeigt, wenn 
ein klassifizierende r Ordnungsbegriff ange- 
wendet wird. Als Beispiel betrachten wir eine Artikelnummer. 





Artikelnummer als klassifizierender Ordnungsbegriff 
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3.8.4 Direktzugriff-Datei mit BASIC 2.0 


Im Gegensatz zu BASIC 4.0 verfügt BASIC 2.0 nicht über die An- 
weisungen DOPEN# (Parameter L legt Satzlänge für Direktzugriff 
fest) und RECORD# (Satzzeiger direkt positionieren). Gleich- 
wohl lassen sich auch in BASIC 2.0 REL-Dateien verwalten: man 
simuliert dazu die Anweisungen DOPEN# und RECORD#. 


Am Beispiel des Programms ART-DIRVERWALT1I wollen wir erklären, 
wie die Anweisungen DOPEN# und RECORD# in BASIC 2.0 simuliert 
werden können. 


3.8.4.1 Direktzugriff-Datei über Menüprogramm verwalten 


Das Programm ART-DIREKTVERWALTI verwaltet eine Artikeldatei, 
die ebenso aufgebaut ist wie die Datei im vorangegangenen Ab- 
schnitt 3.8.3 (Datensatzlaenge 36; vier Datenfelder Artikel- 
nummer, Bezeichung, Menge, Preis). 

Das Menü bietet die drei Wahlmöglichkeiten "Schreiben (=1)', 
'Lesen (=2)' und "Anlegen (=3)' und läßt sich leicht erweitern 
(z.B. durch "Ändern (=4)'!). 

Da die Fehlerabfrage und das Positionieren des Satzzeigers mit 
BASIC 2.0 um vieles aufwendiger ist als mit BASIC 4.0, schrei- 
ben wir diese beiden Anweisungsfolgen als Unterprogramme: Zei- 
len 500-530 zur Fehlerabfrage und Zeilen 700-730 zur Positio- 
nierung des Satzzeigers. 


Codierung zu Programm ART-DIRVERWALTI: 


[...ı.. 
EB re Bu 5 BE ER 


FEINT "WERMALTUNG EIHER ARTIEELDRATEI" 
FEIHNT "UERER DIEEKTZÜGEIFF IM ERSIC 2.0." FRIMT 


m 
uhe 


REN ======V'EREINERRUHNGSTEIL 

DIM Atldı: REM ARFTIKELSATZ MIT & DATEHNFELDERN 

"EM FF. SL: FILE-HNAME. KONSTANTE SHTZLAENGE 

REM 5, SUCH:  SATEHUMMER. SUCHBEGRIFF 

LÖWME. HIGHE: LOWETTE. HIGHFFTE "UER SATENUMMER 
KEN EN.EMF.ET,ES: YARTAELEN FUER FEHLERMELDUNG 
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erece 
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FEN ======AHWNEITSUNGSTEIL 

IFEH 15.53.15. "I" 2 QLOSE 15 0: REM FEHLEREANRL 
IHFUT "DATEIHRAME, SRTELRENGE": F,2L 

FREIHT O"TMENUE AETIEELYERNALTUNG ERSIO 2.8 
FREIHT "GO = EHIDE DES FROGEAMMS" 

FREINT "1 DATEHSRETZE DIEEET SCHREIBER" 

FRINT "zZ = DATENSRETZE DIEEET LESER" 

FRINT "3 = RELATIVE DRTEI LEER ANLEGEN" 

IHFUT EFF! LET E=YALiEHn 


ON E+i1 GOTO zZ. las, ZEA0. DEE: 


FRINT "EB, 1.2 ODER 2": SOTO 2583 
FRIHT "ENDE." : EHE 
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3 FEM ###5CHREIE--LESEFEHLER AEFEAGEHEEREEEEEEFENEEE 


IHFUT#15.EH.EMF.ET.ES 
IF EH=a OR EN=S8 THEH RETURN 


a FEIHT "FEHLER: "SEHIEMFSETIES: STOF 


FEM ###51IMULATIOHN DER AHWETSUNG "RECORDEEREEEN 

LET HIGHE=INT(S2SE : LET LOWNE=SS-HIGHE#ZTE 

FREINT#1S. "F"+CHREE SIEH HCHRELLÖMEI+CHRECHIGHES+CHRECTD 
IF E=3 THEHK "2 : REM FALLS MEU ANLEGEN 

GOSUE Sa: REM FEHLERAFFERGE 

FETLUFH 


REM #&#5RETEE SCHRETEEHFEEEERFEEEEEEFEFETEEEBEEEE 
DFEH 15,59.15 : REM BFEFEHLSKANRAL DEFFHEN 
FEN ##E#5IMULATIOH YON DOPEHEREIEREN 
ÜFEH 1:5,2.F# 
GOSUE 599: REM FEHLERREFEAGE 
FEINT "SRETZE SCHREIBEN (O=ENDEN." 
FEINT "NUMMER. FEZ.. BFESTAHLD. FREIS:" 
INPUT ABEL. AFFEN. AFÜID. A442 
IF Atil:="0" THEN GOTO Il20 
LET S=YALCIRFELND-1aac 


GITO 1050 

LLOSE 15: CLOSE 1 

FEIHT "DATEI GESCHLOSSEN," 

IHPUT "WEITER MIT EETUEN"SEF GOTO 240 


FEM ###5RETZE LESEHEFEFEEEFEEEFEEEEEEEEEEEEREEE 
OPFEH 15.50.15 2 OFEN L.2:2.F$ 

GOSUE Sa: REM FEHLERREFEAGE 

IHFUT "AETIEELNUMMER CA=ENDES": SUCH 

iF SUCH=M THEN GOTO Z128 

LET S=5UCH-1200 

GOSLE Yog : REM SRTZZEIGER FELORD# 
IHFUTHL. REES. HF. HFU2H. AECH2 

IF A&Ul>=SCHRFÜ2GIN THEN 2125 

FRINT "RETIEELNUMMER: "iRfil: 

FREIHT "BEZEICHHUNG: IAFE 

FEIHT "BESTANDSMEHGE: ":rf3) 

FEINT "STUECEFREIS: "Ari :GOTO Z020 
FEIHT "... NICHT GEFUNDEN. ": GOTO ZuE8 
CLÜSE 1: LOSE 15 

FEIHT "DATEI UMWERREHDERT GESCHLOSSEN. " 
IMFUT "MEITER MIT KETURN"I E$: DOTO 242 


FEM ###DATEI ANLEGERN 
INPUT "ANZAHL DER DATENSRETZE": 5 

FEN OE##5IMULATION DOFEH# EHER 

SFEH 15.53.15 : OFEN 1.9.2. "0: "HFF4H".L, "+CHREUSL2 
FEINT "DATEI ";F$;" ERDEFFNET." 

GOSUE 7a: REM SATZZEIGER RECORDE AUF > STELLEN 
FEIHT#1.CHREUZEISS: 

FEIHT "LETZTER SATZ "525" LEER GESCHRIEREN." 
LLESE 1 : CLOSE 15 | 

FRIHT "DATEI GESCHLOSSEN," 

IHPUT "WEITER MIT RETUEH": EF : GOTO 240 
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Ausführung zu Programm ART-DIREKTVERWALTI: 


RUN /RET/ /RET/ für RETURN 
VERWALTUNG EINER ARTIKELDATEI 
UEBER DIREKTZUGRIFF IN BASIC 2.0. 


DATEINAME, SATZLAENGE? DIREKTDATEI, 36 /RET/ 


MENUE ARTIKELVERWALTUNG BASIC 2.0 
ENDE DES PROGRAMMS 
DATENSAETZE DIREKT SCHREIBEN 
DATENSAETZE DIREKT LESEN 
RELATIVE DATEI LEER ANLEGEN 
/RET/ 


VwwND—oO 


wuın N 


ANZAHL DER DATENSAETZE? 20 /RET/ 
DATEI DIREKTDATEI EROEFFNET. 
LETZTER SATZ 20 LEER GESCHRIEBEN. 
DATEI GESCHLOSSEN. 

WEITER MIT RETURN /RET/ 


MENUE ARTIKELVERWALTUNG BASIC 2.0 
ENDE DES PROGRAMMS 
DATENSAETZE DIREKT SCHREIBEN 
DAENSAETZE DIREKT LESEN 
RELATIVE DATEI LEER ANLEGEN 
/RET/ 


wNnD—o 
= ı N 


SAETZE SCHREIBEN (O=ENDE) 
NUMMER, BEZ., BESTAND, PREIS: 
? 1019,STUHL,21,79.50 /RET/ 
NUMMER, BEZ., BESTAND, PREIS: 
? 1002,SESSEL,12,260.90 /RET/ 
NUMMER, BEZ., BESTAND, PREIS: 
0,0,0,0 /RET/ 

DATEI GESCHLOSSEN. 

WEITER MIT RETURN /RET/ 


MENUE ARTIKELVERWALTUNG BASIC 2.0 
ENDE DES PROGRAMMS 
DATENSAETZE DIREKT SCHREIBEN 
DAENSAETZE DIREKT LESEN 
RELATIVE DATEI LEER ANLEGEN 
/RET/ 


WN—OoO 


DBdu uU N 


ARTIKELNUMMER (O=ENDE)? 1004 /RET/ 
... NICHT GEFUNDEN. 
ARTIKELNUMMER (O=ENDE)? 1019 /RET/ 
ARTIKELNUMMER: 1019 


BEZEICHNUNG: STUHL 
BESTANDSMENGE: 21 
STUCKPREIS: 79.50 


ARTIKELNUMMER (O=ENDE)? O0 /RET/ 
DATEI UNVERAENERT GESCHLOSSEN. 
WEITER MIT RETURN ... 
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3.8.4.2 Simulation der Anweisung DOPEN# mit BASIC 2.0 


Der Commodore 64 übergibt der Disketteneinheit (z.B. Floppy 
CBM 1541) einen Befehlsstring für Aufgaben wie das Eröffnen 
einer Datei oder das Setzen des Satzzeigers. 

Der String zum Erzeugen der Anweisung DOPEN# ist so aufgebaut: 


3020 OPEN 1,8,2,'"0:"+F$+",L,"+CHR$(SL) 


Dateinummer 1]. 
Gerätenummer 8 (Floppy) 
Sekundäradresse 2. 


Befehlsstring mit: 
Diskettenlaufwerk 0. 
Dateiname in F$. 
Parameter L für Länge. 
Datensatzlaenge in SL. 


Die Satzlänge darf maximal 254 betragen. Wollen wir eine 
Datei ne u anlegen, muß der gesamte Befehlsstring gesendet 
werden. 

Soll die Datei später (zum Lesen oder Schreiben) geöffnet wer- 
den, so ist lediglich der Filename in F$ im String anzugeben 
(vgl. OPEN in den Zeilen 1020 und 2000). 


3.8.4.3 Simulation der Anweisung RECORD# mit BASIC 2.0 
Der String zum Erzeugen der Anweisung RECORD# lautet: 


700 LET HIGHB=INT(S/256) : LET LOWB=S-HIGHB*256 
710 PRINT#15,"P"+CHR$(96+2)+CHR$(LOWB)+CHR$(HIGHB)+CHR$(1) 


Dateinummer 15 als Be- 
fehlskanal. 


Befehlsstring mit: 
Parameter P (Pointer). 
96 + Sekundäradresse 2. 
Satznummer S in Lowbyte 
und Highbyte zerlegt. 


Das Positionieren des Satzzeigers wird über den Befehlskanal 
15 gesendet. Die Sekundäradresse 2 entspricht der unter OPEN 
angegebenen Adresse. 

Wichtig ist, daß die Satznummer (hier in S) als 2-Byte-Adresse 
in ein nieder- und ein höherwertiges Byte aufgeteilt wird (Ab- 
schnitt 3.5.5.1). 
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3.9 Grafikverarbeitung 


3.9.1 Grafik im Überblick 


Beim Commodore 64 sind drei Grafik-Formen möglich: Die nor- 
male Block- bzw. Liniengrafik, die hochauflösende Grafik (auch 
HIRES-Grafik oder High Resolution Graphics genannt) und die 
Sprite-Grafik. 





Drei Grafik-Darstellungsformen auf dem Commodore 64 


Die Bildschirmaufteilung unterstreicht, daß Computergrafik im- 
mer sehr viel Speicherplatz erfordert. So braucht man zum Ab- 
legen eines Rasterbildes mit 64000 Bildpunkten in HIRES-Grafik 
8K an Speicherplatz. 

Wir gehen auf die zahlreichen Grafik - Programmpakete, die 
komfortabel Linien-, Säulen- und Kuchengrafik (Pie-Chart) dar- 
stellen (vgl. Abschnitt 1.3.8.3), in diesem Buch nicht ein. 
Die folgenden elementaren Beispiele sollen einen ersten Ein- 
druck vermitteln, Probleme durch eigene Programmentwicklungen 
grafisch zu veranschaulichen. 


3.9.2 Normale Grafik 
3.9.2.1 Balkendiagramm 


Programm BALKENDIAGRAMMI löst das Problem der grafischen Ver- 
anschaulichung von Meßwerten als Balkendiagramm bestimmt nicht 
sehr elegant und trickreich, hoffentlich jedoch klar und ver- 
ständlich. 


200 3 Programmierkurs mit BASIC 2.0, BASIC 4.0 und SIMON’s BASIC 


Die Eingabeschleife (200-250) stellt in MAX und MIN die extre- 
men Meßwerte fest, damit sich die Grafikausgabe (280-310) dann 
über die Balkenausdehnung BA daran ausrichten kann. 


Codierung zu Programm BALKENDIAGRAMM]: 


100 REM ======PROGRAMM BALKENDIAGRAMMI 
110 PRINT "BALKENDIAGRAMM ERSTELLEN." 
120 : 

130 REM ======VEREINBARUNGSTEIL 


140 DIM M(20): REM MAXIMAL 20 MESSWERTE 
150 REM ANZ: INTEGER (ANZAHL DER MESSWERTE) 
160 REM MAX,MIN: REAL (MAXIMUM,MINIMUM) 


170 REM B$: STRING (BALKEN) 

180 REM BA: REAL (BALKENAUSDEHNUNG) 

190 REM BL: INTEGER (BALKENLAENGE/ZEILE) 

200 : 

210 REM ======ANWEISUNGSTEIL 

220 REM %*%% ANFANGSWERTERFKKHKIRHKIR KEITH CH 
230 LET MAX = - 9999999999: LET MIN = 9999999999 


240 LET B$ = "HHHHHHHHHHHHHHHHHHHR" 

250 REM 3kMESSWERTE EINGEBEN **kkakksaksakiskiksakiskikikkick 
260 FOR I = 1 TO 20 

270 PRINT I;'. MESSWERT (O=ENDE): ";: INPUT M(I) 

280 IF M(I) = O THEN ANZ = I:I = 20: GOTO 310 

290 IF (M(I) < MIN) THEN MIN = M(I): GOTO 310 

300 IF M(I) > MAX THEN MAX = M(I) 

310 NEXT I: PRINT 

320 LET BA = (MAX - MIN) / 19 

330 REM ekBALKENDIAGRAMMK 3 kkakksksckskaksakskakiksiakikakakikakik 
340 FOR I= 1 TOANZ -1 

350 LET BL= INT (((M(I) - MIN) / BA)) + 1 

360 PRINT I; TAB( 4); LEFT$ (B$,BL) 

370 NEXT I 

380 PRINT "MAXIMUM: '";MAX;'" MINIMUM: ";MIN 

390 PRINT "ENDE.": END 


Zwei Ausführungen zu Programm BALKENDIAGRAMM]1: 


BALKENDIAGRAMM ERSTELLEN. BALKENDIAGRAMM ERSTELLEN. 
1. MESSWERT (O=ENDE): ?12000 1. MESSWERT (O=ENDE): ?103 
2. MESSWERT (O=ENDE): ?14000 2. MESSWERT (O=ENDE): ?95 
3. MESSWERT (O=ENDE): ?11500 3. MESSWERT (O=ENDE): ?15 
4. MESSWERT (O=ENDE): ?10000 4. MESSWERT (O=ENDE): ?55 
5. MESSWERT (O=ENDE): ?14000 5. MESSWERT (O=ENDE): ?187 
6. MESSWERT (O=ENDE): ?13500 6. MESSWERT (O=ENDE): ?0 
7. MESSWERT (O=ENDE): ?0 

1  HHHHHHHHHH 
1  HHHHHHHHHH 2 HHHHHHHHH 
2 HHHHHHHHHHHHHHHHHHH 3 H 
3  HHHHHHHH 4 HHHEH 
4 H | 5  _HHHHHHHHHHHHHHHHHHH 
5  HHHHHHHHHHHHHHHHHHH MAXIMUM: 187 MINIMUM: 15 
6 _HHHHHHHHHHHHHHHHH ENDE. 


MAXIMUM: 14000 MINIMUM: 10000 
ENDE. 
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3.9.2.2 Gerade Y= M*X + B zeichnen 


Zur grafischen Darstellung von mathematischen Kurven werden 
die Achsen häufig vertauscht: die x-Achse nach unten und die 
y-Achse nach rechts. Die Funktion TAB() hat dabei die Aufgabe, 
die Werte der Geraden richtig zu positionieren. 


Codierung zu Programm GERADE]: 


100 REM ======PROGRAMM GERADEI | 

110 PRINT "GERADE Y = M*X + B ZEICHNEN." 

120 INPUT "GERADENSTEIGUNG M: '";M 

130 INPUT "Y-ACHSENABSCHITT B: ";B 

140 INPUT "VON .?. BIS .?. AUF X-ACHSE: ";X0,X1 

150 PRINT "012345678901234567890123456789012345678Y" 


160 FOR X = X0 TO X1 

170 LETTY=M*X+B 
180 PRINT X; TAB( Y);"*" 
190 NEXT X 


200 PRINT "X": END 


Ausführung zu Programm GERADEI: 


GERADE Y = M*X + B ZEICHNEN. 
GERADENSTEIGUNG M: 2 

Y-ACHSENABSCHITT B: 3 

VON .?. BIS .?. AUF X-ACHSE: 0,13 
012345678901234567890123456789012345678Y 
0 * 


3.9.2.3 Linie und Bewegung 


Das Programm LINIEI zeigt, wie eine Linie vom Anfangspunkt SA 
(SA für S)palte A)nfang) zum Endpunkt SE waagerecht gezeich- 
net werden kann. 

Die Anweisung PRINT CR$; steht in einer FOR-Schleife (220) und 
rückt den Cursor bei jedem Schleifendurchlauf um eine Position 
nach rechts bis SA. 

Ist SA kleiner als SE, wird von links nach rechts gezeichnet: 
260 PRINT Z2$; rückt das in Z$ abgelegte Zeichen um eine Posi- 
tion weiter nach rechts (das ";" unterdrückt das normalerweise 
am Ende der PRINT-Anweisung gesendete RETURN). 
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Ist umgekehrt SA größer als SE, wird von rechts nach links ge- 
zeichnet: Mit 320 PRINT 2$;CL$;CL$; geben wir das Zeichen in 
2$ aus, um dann mittels CL$ den Cursor um z we i Positionen 
nach links zu setzen (mit Z$ hatten wir den Cursor ja einmal 
nach rechts gesetzt). 

Die Warteschleife in Zeile 330 verlangsamt den Ablauf, damit 
das Zeichnen der Linie am Bildschirm überhaupt sichtbar wird. 


Das Programm BEWEGUNGI läuft im Prinzip wie das Programm GERA- 
DE1 ab, nur tritt an die Stelle des Befehls "Linie zeichnen' 
jetzt der Befehl "Punkt wandern lassen’. 
Der Punkt besteht wiederum aus dem Zeichnen, das wir in 2$ ab- 
legen. 
Mit der Anweisung 

260 PRINT SP$+Z$+CL$; 
inmitten einer FOR-Schleife bewegen wir den Punkt 2$ von links 
nach rechts: Mit SP$ geben wir eine Leerstelle aus (Space), um 
nach dem Punkt 2$ dann mit CL$ den Cursor wieder um eins nach 
links zu setzen. Beim nächsten Schleifendurchlauf wird dadurch 


Ausführung zu Programm LINIEI: 


RUN 
SPALTE ANFANG (0), ENDE (39)? 5,30 
WELCHES ZEICHEN? - 
(Linie erscheint oben am 
----- -- - -- - - -- -- - - - - -- --- Bildschirm nach Löschen 
des Textes) 


104 REM ======PRÜGRAMM LINIEI 

118 FRINT "EINE LINIE ZWISCHEN ZWEI PUNKTE ZEICHNEN. " 
128 : 

129 REM ======VEREINBARUNGSTEIL 


140 LET CH=CHRFC1I47> : REM HOME 

158 LET CR$=CHRFL 29) : REM CURSOR NACH RECHTS 
168 LET CL#=CHR#i1572: REM CURSOR HACH LINKS 
120 : 

139 REM ======ANWEISUNGSTEIL 

za INFLUT "SPALTE ANFANG Can. ENDE ©5393"; SA.SE 
210 IMFUT "MELCHES ZEICHEN": Z# : FEINT C$; 

228 FÜR I=a TO 5A-1 : FRINT CRE:: NE&T I 

250 IF SA>SE THEN >10 

240 FEM 8&%##LINIE YÜN LINES NACH RECHTSSSEESSEIHISISENEN 
259 FÜR I=5A TO SE 

=68 FRINT Z#; 

zr’a FOR ZEIT=1 TO 58: NE=T ZEIT 

zog NEST I 

230 GOTO 358 

>28 REM #%#LINIE WON RECHTS HACH LINKEERREIEIEEREIERSENE 
>18 FOR I=5A Tü 5E STEF -1 

328 FREINT ZF:CLFCLF: 

>38 FÜR ZEIT=1 TO Se: ME®T ZEIT 

>40 NE=T I 

>50 FEINT : END 
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der Punkt mittels SP$ gelöscht usw. ... . Der Punkt 2$ wandert 
somit von links nach rechts. 
Die Anweisung zum Rückwärtsbewegen 

320 PRINT SP$+CL$+CL$+2$+CL$; 
des Punktes 2$ ist etwas komplizierter: Zusätzlich setzen wir 
vor der Ausgabe des Punktes 2$ den Cursor mittels CL$+CL$ um 
zwei Stellen nach links. Damit erreichen wir einen umgekehrten 
Bewegungsablauf. 


Codierung zu Programm BEWEGUNGI: 


195 REM ======PROGRAMM BEWEGUNGI 

118 FRINT "EIN ZEICHEN ZWISCHEN ZWEI PUNKTEN BEWEGEN. " 
120: 

138 REM ======VEREINBARUNGSTEIL 


144 LET C$=SCHRFI 14T I+CHR#L13>: REM HOME 

129 LET CR$=SCHRFC29H : REM CURSOR NACH RECHTS 
1650 LET CLF=SCHR$U1ST: REM CURSÖR NACH LINKS 
17a LET SFESCHR$C32: : REM SPACE “LEERSTELLE: 
120: 

1320 FEM ======ANWEISUNGSTEIL 

zaa INPUT "SPALTE ANFANG Car, ENDE 393": SA.SE 
z1@ INFUT "WELCHES ZEICHEN"; Z# : FRINT C$: 
zza FOR I=1 TO SA : PRINT CRFI: NERT I 

230 IF 5SA3>S5SE THEN 310 

244 FEM #&#% REM WUANDERT NACH RECHTS EEE 
235g FOR I=SA TO SE-1 

zsa PRINT SPFHSF+CLF: 

ra FOR ZEIT=1 TO 38: NE®T ZEIT 

=50 NE=T I 

aa GOTO 350 

ag REM ###DA5 + WANDERT NACH LINES ZURUECK 
ig FÜR I=SA TO SE STE -1 

sea FEINT SFF+HCLFHCLFHEFHLL$: 

zz FÜR ZEIT=1 TO 58: NE»T ZEIT 

>43 NEAT I 

= FREINT : END 


[. 


3.9.2.4 Grafik-Zeichensatz 


Das Programm BEFEHLSZEILEI demonstriert den Grafik-Zeichensatz 
und die Aufteilung des Bildschirmes in eine Befehlszeile am 
oberen Rand auf der einen und den 'normalen' Bildschirmdialog 
auf der anderen Seite. 

Wenden wir uns zunächst dem Zeichensatz zu. 


Der Grafik-Zeichensatz des Commodore 64 erweitert den Zeichen- 
satz der Commodore-Serien 2/3/4/8000 um die Darstellung in 16 
Farben. 

Durch gleichzeitiges Drücken der Tasten /SHIFT/+/C=/ (mit /C=/ 
ist die neben /SHIFT/ befindliche "(Commodore-Taste" gemeint) 
können wir vom "Groß/Kleinschrift-Modus" in den "Großschrift- 
/Grafik-Modus" überwechseln. 
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Im "Großschrift/Grafik-Modus" erscheinen alle Buchstaben in 
Großschreibung und alle sonstigen Zeichen entsprechend der Be- 
schriftung der Oberseite der Tasten. 

Durch gleichzeitiges Drücken von /SHIFT/ und einer Buchstaben- 
taste bringen wir die Grafik-Zeichen auf den Bildschirm, die 
rechts auf der Tastenvorderseite stehen. Sehr bekannt sind die 
vier Kartenfarben /SHIFT/+ + für Kreuz, /SHIFT/+X für Pik, 
/SHIFT/+S für Herz und /SHIFT/+Z für Karo. 


Bildschirm löschen: 158 FRINT "T' 
4 Kartenfarben ausgeben: 111 PEIHT "+Hhee" 


Gleichzeitiges Drücken von /C=/ und einer Buchstabentaste er- 
gibt die links auf der Tastenvorderseite stehende Grafikzei- 
chen. | 

Untere Tastenreihe links: 


Alle Zeichen des Grafik-Zeichensatzes können wir innerhalb ei- 
ner PRINT- oder INPUT-Anweisung eingeben. 


Codierung zu Programm BEFEHLSZEILE]: 


196 REM ======PRÜGRAMM BEFEHLSZEILEI 

118 REM ======YEREINBARUNGSTEIL 

168 REM T# : TEXT FUER BEFEHLSZEILE 

128 FEM L#$ : LEERSTRING FUER BEFEHLSZEILE 

138 REM ======ANWEISUNGSTEIL 

286 FRINT "STMRDNDNIn"; : REM CURSOR 18 MAL NACH LINTEN 
218 PRINT "SCHRITT 1: PRÜGERMM BEGINNT." 

228 FRINT "DEMONSTRATION: ERGRENZEHD ZUM" 

238 PRINT "BILDSCHIRMIHHALT ERSCHEINT OBEN" 

240 PRINT "EINE BEFEHLSZEILE. " 

258 FRINT "TEXT FUER BEFEHLSZEILE TIFPEN:": INPUT T$ 
268 PRINT: PRINT "SCHRITT 2: BEFEHLSZEILE OBEN ZEIGEN." 
278 REM #%#BEFEHLSZEILE ANFANGS 

258 LET SPALTE=PEEKTZ11>: LET ZEILE=FEER(S145 

238 FOKE 211.8: FOKE 214.0: REM CURSOR NACH SPALTE 3, ZEILE 
>88 SY5 5640 

310 GOSUB 1808 

328 POKE 211.5PALTE: FOKE 214.ZEILE : REM CURSOR ZURUECK 
„30 575 596540 

248 REM &%#BEFEHLSZEILE ENDETE 

326 ERINT: FEINT "SCHRITT 3: PROGRAMM FREHRT FORT." 

36 | 


328 REM KE#UNTERPROGRAMM BEFEHLSZEILE DEUCKERRERERH 

1806 PRINT " ————————————— 1"; 
1818 PRINT "| I"; 
1828 PRINT " m 
10358 LET L$=" " 

1858 PRINT "AH"; L# : REM RAHMENINHALT LOESCHEN 

1868 PRINT "Sl": T# : REM EEFEHLSZEILE IH RAHMEN SCHREIBEN 
1978 FOR I=1 TO 1A00: NET I 

1536 RETURN 
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Im Programm BEFEHLSZEILE1I verwenden wir folgende Grafikzeichen 
zum Zeichnen eines Rahmens: 


/C=/ + A obere links Ecke des Rahmens 

/c=/ + Ss obere rechte Ecke des Rahmens (+ bedeutet 

/C=/ + 2 untere linke Ecke des Rahmens gleichzeiti- 
/c=/ + X untere rechte Ecke des Rahmens ges Drücken 

/SHIFT/ + * waagerechtes Linienstück der Tasten) 

/SHIFT/ + - senkrechtes Linienstück 


Wie die Grafik-Zeichen geben wir auch die Zeichen zur Cursor- 
steuerung dabei innerhalb der PRINT-Anweisung als String ein. 


3.9.2.5 Aufteilung des Bildschirmes in zwei Teile 


Das Programm BEFEHLSZEILEI läuft in drei Schritten wie folgt 
ab: 
In Schritt 1 erscheint - beginnend mit Zeile 10 - dieser Text 
am Bildschirm: 

SCHRITT 1: PROGRAMM BEGINNT. (Programmausgabe) 

DEMONSTRATION: ERGAENZEND ZUM " 

BILDSCHIRMINHALT ERSCHEINT OBEN " 

EINE BEFEHLSZEILE. " 

TEXT FUER BEFEHLSZEILE TIPPEN: " 

1=HYPOTHEK 2=DARLEHEN 3=ENDE (dies tippen wir ein) 

Dann gibt das Programm in der nächst tieferen Zeile den Text 

SCHRITT 2: BEFEHLSZEILE OBEN ZEIGEN. 
aus, um anschließend am oberen (derzeit noch leeren) Bild- 
schirmrand einen Rahmen zu zeichnen und in diesen Rahmen die 
zuvor festgelegte Befehlszeile zu schreiben. Oben am Bild- 
schirm erscheint also: 


1=HYPOTHEK 2=DARLEHEN 3=ENDE 


Der Rahmen wird mit dem Grafik-Zeichensatz ausgegeben. 
Abschließend steht nach dem Durchlaufen einer Warteschleife in 
zeile 1070 unten am Bildschirm die Ausgabe: 

SCHRITT 3: PROGRAMM FAEHRT FORT. 


In die Befehlszeile oben wechseln: 

In den Speicherstellen 211 und 214 des Commodore 64 steht die 
Spalte und die Zeile, in der sich der Cursor gerade befindet. 
In Zeile 280 von Programm BEFEHLSZEILEI retten wir die augen- 
blickliche Cursorposition in den Variablen SPALTE und ZEILE. 
Dann bringen wir in die Adressen 211 und 214 jeweils die Cur- 
sorposition 0 ( 290 POKE 211,0: POKE 214,0 ), da die Befehls- 
zeile oben am Bildschirm erscheinen soll. Mit 300 SYS 58640 
rufen wir eine in Adresse 58640 beginnende Routine auf, über 
die das Betriebssystem die neue Cursorposition verankert. Das 
mit Zeile 1000 beginnende Unterprogramm kann nun die Befehls- 
zeile zeichnen. Ä 


Befehlszeile zeichnen: 

Die Zeilen 1000-1020 enthalten die Grafikzeichen für den Rah- 
men. Die ersten drei Zeichen der Strings in Zeilen 1050-1060 
dienen der Cursorsteuerung: CHR$(19) für 'Home', CHR$(17) für 
'Cursor nach unten' und CHR$(29) für "Cursor nach rechts'. 
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Fortführung des Programms unten am Bildschirm: 

Nach der Rückkehr aus dem Unterprogramm (Zeile 320) POKEn wir 
die alte in den Variablen SPALTE und ZEILE festgehaltene Posi- 
tion des Cursors wieder in die Adressen 211 und 214, um nach 
dem Maschinenprogrammaufruf 330 SYS 58640 mit dem Programm 
unten am Bildschirm weiterzumachen. 


Durch diese Technik können wir den Bildschirm in einen unver- 
änderten Teil (Befehlszeile oben bleibt stehen, gibt z.B. die 
zur Verfügung stehenden Kommandos an) und in einen durchlau- 
fenden Teil (Dialog zwischen Benutzer und Computer) aufteilen. 
Auch das Aufteilen des Bildschirmes in mehrere Fenster als so- 
genannte Windows vollzieht sich im Grunde nach denmsel- 
ben Muster. 


3.9.2.6 Zeichen für Grafik und Cursorsteuerung im Listing 


Im Programm BEFEHLSZEILEI haben wir die Grafikzeichen wie auch 
die Cursorbewegungen in PRINT-Anweisungen zwischen Gänsefüß- 
chen gesetzt. Der Vorteil dieser als "Gänsefüßchen-Modus" be- 
zeichneten Möglichkeit liegt in der einfachen Programmierbar- 
keit. 

Das hier wiedergegebene Beispiel 'Herz in Zeile 1/Spalte 1 am 
Bildschirm zeigen' verdeutlicht diese Vereinfachung: eine 
PRINT-Anweisung in Zeile 100 genügt. 

Dem steht der Nachteil der schlechten Lesbarkeit des Listings 
gegenüber. Auf Typenraddruckern können diese Zeichen zudem 
überhaupt nicht dargestellt werden. Man benötigt dazu Matrix- 
drucker, 





Darstellung von Zeichen für Grafik und Cursorsteuerung 


Beim 'CHR$()-Modus' als alternativer Möglichkeit geben wir die 
entsprechenden Zeichen über die CHR$()-Funktion an. Wie unser 
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Beispiel 'Herz links oben ausgeben' zeigt, ist die Programmie- 
rung umständlicher, aber besser lesbar. Das 'Herz' als Grafik- 
Zeichen können wir dabei z.B. wie folgt ausgeben: 


(1) 140 PRINT CHR$(115); CHR$() jeweils direkt. 


(2) 130 LET HERZ$=CHR$(115) Stringvariable. 
140 PRINT HERZ$; 


(3) 130 LET HERZ=115 Numerische Variable. 
140 PRINT CHR$(HERZ); 


Soll das 'Herz' wiederholt ausgegeben werden, so bieten sich 
Vorgehensweisen (2) oder (3) an. 


Neben diesen beiden Möglichkeiten des '"Gänsefüßchen-Modus' und 
'CHR$()-Modus' gibt es eine dritte Möglichkeit über spezielle 
Routinen, die zumeist die Zeichen zur Cursorsteuerung in Kür- 
zel umwandeln, so z.B. in 100 PRINT ""CLEAR' 'UNTEN'"'RECHTS'". 


3.9.3 Hochauflösende Grafik mit SIMON’s BASIC 


Das standardmäßig im ROM des Commodore 64 bereitgestellte 
BASIC 2.0 enthält keine Anweisungen, die die hochauflösende 
Grafik unterstützen. Das bedeutet, daß wir die 200%320=64000 
Bildpunkte des Grafikspeichers über PEEKs und POKEs belegen 
müssen. Die Grafikprogrammierung wird kompliziert, da wir da- 
bei Bit für Bit vorgehen müssen und ein Bitmapping notwendig 
ist (Map für Karte; Grafikspeicher als Grafikkarte vorstell- 
bar). 

SIMON's BASIC hingegen verfügt über zahlreiche Grafikbefehle, 
die das Programmieren in HIRES-Grafik wesentlich vereinfachen. 
Aus diesem Grunde verwenden wir in den folgenden Beispielen 
die Anweisungen von SIMON's BASIC. 


3.9.3.1 Zwei Punkte durch Linie verbinden 


Mit Programm HIRESLINIE-SIMON können wir zwei Punkte mit einer 
Linie verbinden. Drei Unterschiede zum Programm LINIE1I von Ab- 
schnitt 3.9.2.3 sind wichtig: 

- HIRES-Grafik; Punkte der Geraden liegen enger beieinander. 

- Gerade muß nicht waagerecht sein. 

- Grafik-Anweisungen HIRES und LINE von SIMON's BASIC. 


Mit der Anweisung 

240 HIRES 1,0 
legen wir für die zu zeichnenden Punkte eine weiße Farbe (1) 
und für den Hintergrund eine schwarze Farbe (=0) fest. 
HIRES 0,1 würde umgekehrt schwarze Punkte auf weißen Hinter- 
grund ausgeben. 
HIRES schaltet dabei den Bildschirm auf hochauflösende Grafik 
mit 200*320=64000 Bildpunkten um. 
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Dh ame, Bandes 317,318,319 


-200 Zeilen waagerecht 
mit Y-Koördinate, von 

0 bis 199 gezählt. 

-320 Spalten senkrecht 

+ mit %-Koordinate, von 
R(300/120) 0 bis 319 gezählt. 
-654000 Bildpunkte. 

-Punkt P(0/0) links oben. 
-Punkt 0(0/199) links 
unten, 





Bildschirmaufbau für hochauflösende Grafik 


Zum Zeichnen einer Verbindungslinie zwischen dem Anfangspunkt 
P1(x1/x2) und dem Endpunkt (X2/Y2) verwenden wir die Grafik- 
Anweisung 

250 LINE X1,Y1,X2,Y2,1 
wobei der letzte Parameter un den Zeichentyp angibt: 

- Zeichentyp 0: Punkt löschen 


Ausführung zu Programm HIRESLINIE-SIMON: 


RUN 
ANFANGSPUNKT X1,Y1? 50,180 
ENDPUNKT x2,Y2? 319,0 


/TASTE/ FUER ZEICHENBEGINN 


(Bei Drücken einer Taste 
verschwindet der Textdialog 
und am Bildschirm erscheint 
die nebenstehende Linie von 
P1(50/180) bis P2(Eckpunkt 
rechts oben). 


Codierung zu Programm HIRESLINIE-SIMON: 


150 REM ======PROGRAMM HIRESLIHIE-ZIMON 

114 PRINT "DEMONSTRATION: LINIE ZEICHNEN" 

120 REM ©SIMON’S BASIC, HIRES-GERFIK 

130 : 

140 REM ======VEREINBARUNGSTEIL 

159 REM x1. 71: KOORDINATEN DES ANFANGSFUNKTES 

150 REM x2,72: KOORDINATEN DES ENDPUNKTES 

170 : 

130 REM ======ANMEISUNGSTEIL 

198 PRINT "cWAAGERECHT GCH(313, SENKRECHT BCYC13S2" 
298 INPUT "ANFANGSPUNKT #1, Y1"5 KL. 

218 INPUT "ENDPUNKT Kaya 

538 PRINT "TASTE? FUER ZEICHENBEGINN" 

>30 GET E$: IF E$="" THEN 230 

248 HIRESI.G : REM PUNKT HEISS &1> HINTERGRUND DUHKEL (en) 
258 LIHE X1,W1.82,72,1 : REMLINIE ZEICHNEN 

268 GOTO 268 : REM GRAFIK BLEIBT BIS /RUN-STOP? 
278 END 
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- Zeichentyp 1: Punkt zeichnen 
- Zeichentyp 2: Punkt umkehren (gelöschten Punkt zeichnen 
bzw. existierenden Punkt löschen) 
Die Endlosschleife 260 GOTO 260 dient dazu, daß die gezeich- 
nete Linie solange am Bildschirm erhalten bleibt, bis z.B. die 
Taste /RUN-STOP/ gedrückt wird. Wir können die Grafik so z.B. 
ausdrucken. 


3.9.3.2 Kurve plotten 


Das Programm HIRESKURVE-SIMON zeichnet bzw. plottet eine Kurve 
mit der Grafik-Anweisung PLOT in einem Koordinatenkreuz. 


Ausführung zu Programm HIRESKURVE-SIMON: 


RUN 

PARAMETER A,B,C? 0.5,-1,-50 
(Dieser Text verschwindet. 
Links erscheint die X-Achse, 
dann von oben nach unten der 
linke Parabel-Ast, dann die 
Y-Achse, dann wird mit der 
X-Achse und dem rechten Ast 
fortgefahren. 

Das Koordinatenkreuz steht 
auf Bildschirmmitte, die Pa- 
rabel ist nach rechts unten 
verschoben). 


Die X-Achse zeichnen wir Schritt für Schritt zusammen mit der 
Kurve durch die Anweisung 
370 PLOT X1,100,1 PLOT zeichnet einen Punkt. 


X1 als X-Koordinate. 
100 als Y-Koordinate (Zeile 
auf Bildschirmmitte). 
1 als Zeichentyp (zeichnen). 


Mit 100 wählen wir für die X-Achse die mittlere Position Zzwi- 
schen oben (Zeile 0) und unten (Zeile 199). 


Die Y-Achse ziehen wir mittels 

350 LINE 160,199,160,0,1 „ 
sobald wir beim Plotten der Kurve die mittlere Spaltenposition 
erreicht haben (Position X=0 bzw. X1=160 ; deshalb die Abfrage 
340 IF X<>0 THEN 360). Die LINE-Anweisung haben wir bereits in 
Abschnitt 3.9.3.1 kennengelernt. 
Häufig zeichnet man zuerst das Koordinatenkreuz und erst an- 
schließend die Kurve. 


Das eigentliche Zeichnen der Kurvenpunkte geschieht durch die 
Anweisung 

360 PLOT X1,Y1,1 
mit (X1/Y1) als Koordinaten und "1" als Zeichentyp 'zeichnen'. 
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Da der Nullpunkt der HIRES-Grafik links oben im Bildpunkt 
N(X=0/Y=0) liegt, unser Nullpunkt des Koordinatenkreuzes hin- 
gegen im Punkt N1(X=160/Y=100), müssen wir die Koordinaten 
verschieben: 

310 LET X1=X+160 : LET Y1=100-Y 


Die Abfragen in den Zeilen 320 sowie 330 verhindern, daß das 
Programm die Ausführung mit einer Fehlermeldung abbricht, wenn 
Y-Werte auftreten, die über 199 oder unter 0 liegen, die also 
außerhalb des Grafik-Speichers gezeichnet würden. 


Mit dem Programm können wir beliebige Parabeln der Form 

Y= A*X*X + BX + C 
zeichnen - je nach der Eingabe von A, B und C. Am schnellsten 
wird man mit dem Programm vertraut, wenn man einige Kurvendia- 
gramme erprobt und das Programm modifiziert. Ersetzen wir die 
Schrittweite STEP I in Zeile 290 z.B. durch STEP 0.5 ,„ so 
werden die Bildpunkte enger beieinander liegen. 


Codierung zu Programm HIRESKURVE-SIMON: 


106 REM ======FROGEANMM HIRESEURVE-SIMON 

110 FEM FPARFRBEL DER FORM Y=Akktz+Bss+l ZEICHNEN. 
120 FEM SIMON”S BASIC. HÖOCHAUFLOESENDE GEAFIE. 
138: 

14a REM ======VEREINEARUNGSTEIL 

159 REM A,E,C: PARAMETER FUER KURYE 

1E0 FEM 5.7: KOORDINATEN FUER KURVYE 

ira REM =1.'71: KOORDINATEH YVERSCHORFEN FUER GEAFTERUSGABE 
128: 

128 : 

30 REM ======ANWETSUNGSTEIL 


218 REM FARAMETER FUER KURWE Y = Aka + Ba + C FESTLEGEN 
z28 IHPUT "FRARERMETER R.B.C"IR,E.C 


240 REM PUNKTE=WEISS C15. HIHNHTERGRUND=SCHUARZ (E3 


2sg HIRES 1,0 


268 
288 REM SCHLEIFE: ZEICHNEN YON LIHKSCH=-1858) NACH RECHTS CX=159) 
299 FOR X=-16@ TO 159 STEP 1 

300 LET = + Ak + BEk + 0 : REM Y-KOORDINATE 


218 LET x1=%+160 : LET Ti1=106-7 : REM NULLPUNKT VERSCHIEBEN 
a20 : IF x1<a OR %1>313 THEN 370 

229 : IF vi<a OR Y71>193 THEN 37 

48: IF x<>a THEN 360 

258: _IHE150,192,168,0,1 : REM Y-ACHS 

3EQ PLSTS1.P1,1 : REM PUNKT FUER KURVE 

378 FLOT%I 100.1 : REM FUNKT FUER ®-ACHSE 

=38 NEXT = 

339: 


418 REM WARTESCHLEIFE: GRAFIK VERSCHWINDET BEI RUN-STOR/ 
429 GOTO 42 
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3.9.4 Sprite-Grafik mit SIMON’s BASIC 


Ein Sprit e ist ein programmierbares Objekt in hochauflö- 
sender Grafik, das maximal 24 Punkte breit (X-Richtung waage- 
recht) und 21 Punkte hoch (Y-Richtung senkrecht) sein kann und 
als eine Einheit am Bildschirm bewegt wird. | 
Jedes Sprite belegt damit 63 Bytes an Speicherplatz: 3 Bytes 
für die jeweils 24 (=3*8) Bildpunkte einer waagerechten Zeile 
sowie 21 Bytes für die 21 untereinanderstehenden Zeilen. 


Verwendet man BASIC 2.0, muß jeder Punkt bzw. sein Bitmuster 
in den RAM gePOKEd werden. Die Sprite-Programmierung wird da- 
mit sehr aufwendig. 

SIMON's BASIC stellt spezielle Anweisungen bereit, wodurch das 
Konstruieren von Sprites wesentlich vereinfacht wird. Aus die- 
sem Grunde verwenden wir das SIMON's BASIC. 

An einem einfachen Beispiel wollen wir erklären, wie man ein 
Sprite konstruiert und dann während der Programmausführung auf 
dem Bildschirm hin und her bewegt. 


3.9.4.1 Ausführung eines Programms mit einem Sprite 


Lassen wir das Programm DEMO-SPRITEI mit RUN laufen, erscheint 
zunächst folgender Text am Bildschirm: 


RUN /RET/ 
TASTATURGESTEUERTES BEWEGEN EINES SPRITE. 


ALS TASTEN ZUR STEUERUNG VEREINBART: 
TASTE A: SPRITE NACH LINKS 

TASTE S: SPRITE NACH RECHTS 

TASTE W: SPRITE NACH OBEN 

TASTE Z: SPRITE NACH UNTEN | 

ENDE DURCH /RUN-STOP/ UND /RESTORE/ 
WEITER MIT RETURN. 


Die links auf der Tastatur angeordneten Tasten A, S, W sowie 2 
dienen der Steuerung des Sprite (drücken wir die Taste A, be- 
wegt sich das Sprite also nach links). 

Das Progamm weist eine Endlosschleife auf; die Programmausfüh- 
rung beenden wir durch gleichzeitiges Drücken der beiden ange- 
gebenen Tasten. 


Tippen wir RETURN, so wird der Bildschirm gelöscht und oben in 
der Mitte des Bildschirmes erscheint ein Sprite, das - je nach 
Phantasie - wie das Gesicht eines Affen, Bit-Beißers oder ein- 
nes Geistes aussieht. Sobald das Sprite ganz aufgetaucht ist, 
bleibt es stehen. 
Nach kurzer Zeit wandert es nach unten, um bei Erreichen des 
unteren Bildschirmrandes mit der Mitteilung 

ENDE, DA BILDSCHIRMRAND BERUEHRT. 
zu verschwinden. 
Kurze Zeit später erscheint das Sprite von neuem oben am Bild- 
schirm und derselbe Vorgang beginnt von neuem. 
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Diesen sich endlos wiederholenden Vorgang können wir unterbre- 
chen, in dem wir Steuertasten drücken. 

Durch Drücken der Steuertasten A, S, W bzw. Z bewegen wir das 
Sprite nach links, rechts, oben bzw. (beschleunigt) auch nach 
unten. Halten wir eine Taste gedrückt, dann wandert das Sprite 
solange in die befohlene Richtung, bis es den Bildschirmrand 
berührt. 

Dieses Steuerungsprinzip ist typisch für alle Programme, bei 
denen der Benutzer die Möglichkeit hat, Objekte am Bildschirm 
hin und her zu bewegen. 

Betätigen wir irgendeine andere Taste, bleibt das Sprite ste- 
hen, bis wir die Taste wieder loslassen. 

Durch /RUN-STOP/ brechen wir die Programmausführung ab. 

Ein Hinweis: Falls überhaupt kein Sprite am Bildschirm sicht- 
bar wird, müssen wir die Hintergrund- und Zeichenfarbe ändern 
(z.B.: POKE 53281,1 setzt Hintergrund hell). 


3.9.4.2 Sprite speichern und auf den Bildschirm bringen 


Wenden wir uns nun der Codierung von Programm DEMO-SPRITE]I zu, 
die in fünf Punkte gegliedert ist. 


"1. Definition des Sprite (MOB)": 
Zunächst wird mit der DESIGN-Anweisung ein Speicherbereich für 
das Sprite reserviert. 


210 DESIGN 0,13%64 


Sprite in HIRES-Grafik (1 für Mehrfarben). 
Anfangsadresse 13%64=832 für die Abspei- 
cherung des Sprite. 


Jedes Sprite benötigt 64 Bytes Speicherplatz: 63 Bytes für die 
insgesamt 24%21 Bildpunkte zuzüglich 1 Byte, das aus Gründen 
der Speicherorganisation hinzugefügt werden muß. Das 1. Sprite 
kann im 13. Block abgelegt werden (ab Adresse 832) und das 2. 
Sprite in Block 14 (ab Adresse 14%64=896) usw. 

Bis zu acht Sprites lassen sich gleichzeitig auf dem Monitor 
bewegen. Im RAM dagegen können wir soviele Sprites speichern, 
wie Platz vorhanden ist. 

Das Mehrfarbensprite (erster Parameter gleich 1) ist nur halb 
so groß (12%*21-Matrix) wie das Sprite in hochauflösender Gra- 
fik (24%*21-Matrix) 


Nach dem Bereitstellen von Speicherplatz können wir mithilfe 
des Klammeraffen das Sprite konstruieren. 

In jeder der 21 Programmzeilen 220-420 stehen hinter dem Klam- 
meraffen 24 Zeichen. Hier ein Beispiel für eine Sprite-Zeile: 


600 ©..BB..CBSDD......BBDD..B 


Punkt für Hintergrundfarbe. 
B für Farbe in CMOB genannt. 
C für Farbe in MOB SET. 
D für 2. Farbe in CMOB. 


3.9 Grafikverarbeitung 213 


Die Zeilen mit dem Klammeraffen müssen stets nach der DESIGN- 
Anweisung stehen. 


Wir kommen nun zum nächsten Gliederungspunkt der Codierung, zu 
"2. Sprite-Aufbau festlegen": 

Diesen Aufbau geben wir mit der Anweisung MOB SET an. Mit dem 
Kürzel MOB (Movable Object Block für beweglicher Objekt-Block) 
wird in SIMON's BASIC das Sprite bezeichnet. 


460 MOB SET 0,13,0,0,0 


Sprite-Nummer O0, unter der das Sprite 
aufgerufen wird (möglich: 0,1,...,7). 
Sprite in Block 13 (ab 13%64-=-832 ge- 
speichert. 

Farbe O0=-schwarz (möglich: 0,1,..,15). 
Sprite erscheint vor (0) den normalen 
zeichen, nicht aber dahinter (1). 
Sprite in hochauflösender Grafik (0), 
kein Mehrfarben-Sprite (1) 


Nach Ausführung dieser MOB SET-Anweisung ist dem Sprite eine 
Nummer zugeordnet (Nummer 0), unter der es später aufgerufen 
werden kann. Nun müssen wir es vom Speicherblock 13 auf den 
Bildschirm bringen. 

Dies geschieht durch die MMOB-Anweisung, die im Gliederungs- 
punkt "3. Sprite erscheint" so codiert ist: 


490 MMOB 0,160,0,160,50,0,255 


Sprite mit Nummer 0 wird dargestellt. 
X1=160 Startkoordinaten: Sprite be- 
Y1=0 wegt sich von diesem Punkt. 
X2=160 Zielkoordinaten: Sprite be- 
Y2=50 wegt sich zu diesem Punkt. 


0 für normale Größe des Sprite. 
255 für langsamste Geschwindigkeit 
(1 £für schnellste Geschwindigkeit). 


Der Nullpunkt (0,0) ist links oben am Bildschirm. Das Sprite 
bewegt sich somit von der ungefähren oberen Bildschirmmitte 
(160,0) senkrecht um 50 Einheiten nach unten nach (160,50). In 
diesem Punkt bleibt das Sprite für einige Zeit stehen (Warte- 
schleife in Zeile 500). 
Der vorletzte Parameterwert legt die Größe des Sprite fest: 

0 - normale Größe (hier gewählt) 24%21 

1 Verdopplung der X-Ausdehnung 48%21 (breiter). 

2 Verdopplung der Y-Ausdehnung 24%42 (schmaler). 

3 Verdopplung von X.wie Y 48%42 (extrem) 
Eine etwaige Verdopplung des Sprite muß bei den Punktkoordina- 
ten natürlich berücksichtigt werden. 


214 3 Programmierkurs mit BASIC 2.0, BASIC 4.0 und SIMON’s BASIC 


3.9.4.3 Tastaturgesteuertes Bewegen eines Sprite 


Im Mittelpunkt des Gliederungspunktes "4. Sprite-Bewegung über 
Tastatur" steht die RLOCMOB-Anweisung: 


650 RLOCMOB 0,X,Y,0,1 


Sprite mit Nummer 0 wird bewegt. 

Vom derzeitigen Punkt bewegt sich das 
Sprite zum Punkt (X,Y) als Zielpunkt. 
0 als normale Größe des Sprite. 

1 als schnellste Geschwindigkeit. 


während die Anweisung MMOB das Sprite erstmalig auf den Bild- 
schirm bringt, bewegt es die Anweisung RLOCMOB zu den durch X 
und Y angegebenen Koordinaten. 

Die Werte von X und Y ändern wir in Abhängigkeit der jeweils 
gedrückten Steuertasten 


Steuertaste: PEEK(203): Bewegung des Sprite: 

Taste W 9 um 3 nach oben: Y=Y-3 

Taste A 10 um 3 nach links: X=X-3 

Taste S 13 um 3 nach rechts: X=X+3 

Taste 2 12 um 3 nach unten: Y=Y+3 
ab. 


Dazu fragen wir mit der Anweisung 

540 LET TA = PEEK(203) 
die gerade gedrückte Taste ab und weisen ihren Tastenwert der 
Variablen TA zu. 
Ist TA=64, d.h. wurde überhaupt keine Taste gedrückt, erhöhen 
wir Y um 3. Damit wird erreicht, daß das Sprite einen "Drang 
nach unten' bzw. eine "gewisse Schwere' erhält. 
In einer Schleife (Zeilen 540 bis 700) fragen wir wiederholt 
über PEEK(203) die Tastatureingabe des Benutzers ab, um entwe- 
der das Sprite entsprechend zu bewegen (RLOCMOB-Anweisung in 
zeile 650), oder um im Falle des Anstoßens am Bildschirmrand 
die Bewegung zu beenden (IF-Anweisungen in Zeilen 680-690). 


Durch das Testprogramm 

1 LET TA=PEEK(203) 

2 PRINT TA 

3 GOTO 10 
können wir sehr schnell prüfen, welche Tastenwerte der Commo- 
dore 64 in Adresse 203 ablegt. 


Stößt das Sprite am Bildschirmrand an, lassen wir es durch die 
Anweisung MOB OFF 0 verschwinden (0 als Spritenummer). 
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Codierung zu Programm DEMO-SPRITEI: 


‚au 
118 
128 
150 
148 
150 
1&0 
ir 
1506 
1>u 
ud 
21a 
ze 
30 
248 
250 
260 
era 
280 
230 
308 
31a 
Ss2u 
330 
a4 
358 
364 
sro 
Re T= 15) 
398 
+00 
+18 
+28 
+30 
448 
450 
460 
4’0 
434 
498 
ag 
s18 
220 
538 
Ss4ua 
258 
360 
Sr B 
280 
Sı90 
sau 
618 
520 
634 


REN ======FRÜGRAMM DEMO-SPFRITEI 
PRINT "ITASTATURGESTELIERTES BEWEGEN EINES SFRITE": FRINT 


PRINT "RL5S TASTEN ZUR STEUERUNG VEREINBART: " 


215 


FREINT "TASTE R: 5SFRITE NACH LINES": PRINT "TASTE 5: SFRITE NACH RECHTS" 
PRIHT "TRSTE WM: SFRITE NACH ÜBEH": FRINT "TRSTE Z: SFRITE HACH UNTEH" 


PRINT "ENDE DURCH “RUN-STOFF UND ZRESTORE#" 
PRINT "MEITER MIT RETURN." 


REN ###1. DEFINITION DES SFRITE “MÜRSERREFERE 
DESIGN D.13464 
GBEBERBBEREBERFBEBBEBEREEER 


@BEREBEBERBBEBEBEBERBEEBEEBE 
GERBRERBBEBEEEBBBREBEBBBERER 
G@ERERR EREBEB BBERBR 
GBEREB ERERBR EREEBE 
@BBERR BEBEBER BEBER 
G@EBEBE EBEEBR BEREE 
@BEBEBREBEBBEREBBEBREBEBBBREER 


@EREBEBBREEBBEBEBBERRERERER 
WBERBEREBEBEBE BBBERERBEBEE 
@GERBEEEBEEEB BBEBEBERBER 
@GEEBEBEBBERBEBB EBEBEBEEBBEEB 
GEBERBBBEEER BBEEBEBEERBE 
@EERBBEBBEER BBEBRBEBBER 
@GEBBEEBREBER BBEBERBEBER 
BGERBBEBBBBEEEBBBBBBBBERBEBER 
@EBBBERBEBEBEBBREBEBBERBBE 


BERE BEB 
GEBR BER 
BGERBEBEREBBEEBEBBBEBBBEEBER 


@EBERERBERBERBBEBBEBBBEBEBE 


REN #2. SPRITE-RUFBAU FESTLEGENFFEHFERERFTTERTEN SE: 
PRINT "22" 
MOB SET 4.13.0.0,8 


REM ##4#3. SPRITE ERSCHETINTFEFFHFERRRRTERTETETTETERE TEEN 
MMOB 0.16590,0.160.50.0.255 

FÜR ZEIT=1 TO 1804: NEXT ZEIT 

LET »=160 : LET Ya 


REM ###4. SPRITE-BEHEGUNG LIEBER TASTRTURFEHSRER 
LET TR=FEERTZU3> 

REM ###KEINE TASTE: FRALLENFHRRER 
IF TR=64 THEN LET Yelr+3 

REM ##TRSTE HM: HÜCHFEFFERHTTETTERT N: 
IF TR=3 THEN LET T=eYr-3 

REM #4#TRSTE R! LINKSIHFTREREREN 
IF TR=1G THEN LET Ask: 

REN ##4#TRSTE 5: RECHTSIRHRFEFTEHFEN 
IF TAR=13 THEN LET K=ä+3 

REM #4#TRSTE Z: UNTEN 
IF TA=12 THEH LET Yaelr+3 

FLOCMOR 8,%.7.0.1 
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sro 
630 
590 
aa 
18 
ra 
3@ 
"48 
=] 
"68 
"78 
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REM ###ENDE AM BILDSCHIRMRANIEEH 
IF viSe OR Y>Z30 THEN 740 

IF z<27 OR x>316 THEN 740 

GOTO >40 


REM #445. BILDSCHIRMRAND BEENDET RBELRUFFRHTERN 
muB OFF 8 

FRINT "WENDE. DA BILDSCHIRMRAND BERUEHRT ." 

FÜR ZEIT=1 TO 1aad: NET ZEIT 

GOTO 450 
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3.10 Programmstrukturen mit SIMON’s BASIC 


Auf die grundlegenden Programmstrukturen (Folge, Auswahl, Wie- 
derholung und Unterprogramm) sind wir mehrfach eingegangen: in 
Abschnitt 1.3.3 allgemein und in Abschnitt 3.1 an Programmbei- 
spielen mit BASIC 2.0. 

SIMON's BASIC stellt uns Anweisungen zur Verfügung, welche das 
Programmieren insofern vereinfachen, als eine Anweisung genau 
jeweils einer bestimmten Programmstruktur entspricht. Das oft 
recht umständliche Arbeiten mit GOTO- und IF-Anweisungen wird 
durch klare und übersichtliche Kontrollanweisungen ersetzt. 
SIMON's BASIC erreicht damit eine gewisse Ähnlichkeit mit den 
höher strukturierenden Programmiersprachen wie MODULA-2 oder 
PASCAL. 


3.10.1 Auswahlstruktur mittels IF-THEN-ELSE 


Das Programm SKONTOZWEI-SIMON stimmt in der Ausführung (RUN) 
genau mit dem Programm SKONTOZWEISEITIG von Abschnitt 3.1.2.1 
überein. 

Die BASIC-Codierung hingegen ist anders: muß in BASIC 2.0 mit 
GOTO- und IF-Anweisungen programmiert werden, so steht uns in 
SIMON's BASIC die IF-THEN-ELSE-Anweisung zur Verfügung. Anders 
als z.B. bei PASCAL muß das Befehlswort ELSE stets zwischen 
Doppelpunkten ":" stehen. 

Eine IF-THEN-ELSE-Anweisung entspricht genau einer 

zweiseitigen Auswahlstruktur. Das Struktogramm veranschaulicht 
dies, 


Struktogramm zu Programm SKONTOZWEI-SIMON: 


Rechnungsbetrag R und Tage T eingeben 
IF 


T>8 (wenn) 










ELSE (sonst) 





THEN (dann) 








P=1.5 zuweisen P=-4 zuweisen 


Skonto S=R*P/100 und Zahlung R=R-S 
berechnen und dann als Ergebnis ausgeben 


Beispiele für IF-THEN-ELSE-Anweisungen: 

- IF ... THEN PRINT "GROSS" : ELSE : GOTO 400 

- IF „.. THEN GOSUB 200 : ELSE : END 

- IF ... THEN PRINT LET MARKE=1 : ELSE : EXEC UNTERPROG4 

- IF ... THEN LET A=9 : ELSE : CALL ERKLAERUNG 
Auswahlstrukturen lassen sich hintereinander oder geschachtelt 
anordnen. Dasselbe gilt für IF-THEN-ELSE-Anweisungen. 
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Codierung zu Programm SKONTOZWEI-SIMON: 


150 REM ======FRÜGRAMM SEOHTOZWEISIMÖON 

ig1 REM ©SIMON”S EASIC. MIT IF-THEN-ELZE 
105 REM SIEHE PROGRAMM SKONTOZHEISEITIG> 
194 REM ======ANHEISUNGSTEIL 

115 FRINT "SKONTO ALS ZWEISEITIGE AUSWAHL." 
128 INFUT "RECHNUNGSBETRAG IN DM";F 

1328 INFUT "TAGE HACH ERHALT ",T 

146 IF T>3 THEN LET F=1.5 :EiL3E: LET Fed 
1650 LET 5=R#P-103 : LET R=R-5 

17&G PRINT 5; "DM SKONTO UNHD":R: "IM ZAHLUNG." 
123 FRINT "EHDE." : END 


3.10.2 Nicht-abweisende Schleife mittels REPEAT-UNTIL 


Drei der vier Arten von Wiederholungsstrukturen werden durch 
SIMON's BASIC durch spezielle Anweisungen unterstützt: 


- Nicht-abweisende Schleife (REPEAT-UNTIL) 
- Schleife mit Abfrage in der Mitte (LOOP-EXIT-END LOOP) 
- Zählerschleife (FOR-NEXT) 


- Abweisende Schleife (Konstruktionen mit IF und GOTO nötig) 
Wir wenden uns zunächst der Anweisung REPEAT-UNTIL zu. 


Die Ausführungen der Programme KAPITAL2-SIMON sowie KAPITAL2 
(Abschnitt 3.1.3.2) sind gleich, die BASIC-Codierungen jedoch 
weichen voneinander ab. 
In Programm KAPITAL2-SIMON wird die Wiederholungsstruktur mit- 
tels REPEAT-UNTIL codiert: REPEAT setzt den Schleifenanfang 
und UNTIL das Schleifenende fest. 
Da die Endebedingung über 

240 UNTIL K>=KE 
am Ende der Schleife abgefragt wird, werden die Anweisungen in 
der Schleife mindestens ein Mal durchlaufen. 


Struktogramm zu Programm KAPITAL2-SIMON: | 


Eingabe: Anfangskapital K und Zinssatz P 
Berechnung: Endkapital KE=2*K als das doppelte K 


Erhöhung von K um die Zinsen K*P/100 








Ausgabe: derzeitiges Kapital K 






Wiederhole .... bis K größer oder gleich KE ist 
211 REPEAT .... 240 UNTIL K>=KE 













Ausgabe: Ende nach Verdopplung des Anfangskapitals 
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Codierung zu Programm KAPITAL2-SIMON: 


10% 

ic1 REM £©SIMÖN”S BASIC. REFERT-UHTILN. 

igZ REM SIEHE FEOÖGRAMM EAPITAL2) 

118 FEINT "KAFITALIEN EIS ZUR YERDÖFPLUNG. 


120 REM K: REAL KAPITAL IN DM 
i4G REM KE:’ FERL VENDERFITAL IN DM: 
154 REM P: FERL CZINSSATE IN DM) 


168: 

178 EEM ======ANMEISUNGSTEIL 

129 INPUT "EINGESETZTES ERFITAL"K 
129 INPUT "JAHRESZINSSATEZ ";F 


290 LET KE= 2 * K 
210 REM XE#BEGINN DER NICHT-ABWEISENDEN SCHLEIFEIKKE 


>28 LET K=k+k#P 100 

238 PRINT" ";K 

248 UNTIL KoskE | 

250 REM #%#SCHLE IFENENDEFFERREEHRSERRRREEE 
>68 PRINT "ENDE NACH VERDOPPLUNG." : END 


3.10.3 Schleife mittels LOOP-EXIT-END LOOP 


Das Programm ZEITSTOP-SIMON umfaßt eine "Schleife mit Abfrage 

in der Mitte' als Wiederholungsstruktur, die durch die Anwei- 

sung LOOP-EXIT-END LOOP programmiert wird: 

- 180 LOOP setzt den Schleifenbeginn. 

- 210 END-LOOP setzt das Schleifenende. 

- 200 EXIT IF E$<>"" fagt die Bedingung zum Verlassen der 
Schleife (irgendeine Taste gedrückt) ab. 


In der Variablen TI (für TIme, Zeit) speichert der Commodore 
die Zeit ab (TI=0 beim Anschalten des Computers, TI=TI+1 alle 
1/60 Sekunden). 

Mit 160 LET UHR=-TI halten wir die Startzeit in UHR fest, um 
später nach dem Verlassen der Schleife mit 220 LET UHR=TI-UHR 
die abgelaufene Zeitspanne in UHR abzuspeichern. Auf diese Art 
können wir den Computer als 'Stoppuhr' verwenden. Die Schleife 
dient dabei als Warteschleife (vgl. Abschnitt 3.1.3.7). GET E$ 
wird wiederholt durchlaufen; sobald eine Taste gedrückt wurde, 
ist der String E$%XK?>"" (d.h. nicht mehr leer) und die Schleife 
kann über EXIT verlassen werden. 

Die Anweisung EXIT IF E$<>"" verzweigt in die Programmzeile, 
die der Anweisung END LOOP folgt. 
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Struktogramm zu Programm ZEITSTOP-SIMON: 
Texte mit Hinweisen ausgeben 


Wertzuweisung UHR=TI, sobald Taste gedrückt wurde 


180 LOOP Beginn der Schleife 


Möglichkeit zur Eingabe eines Zeichens über GET 


00 EXIT IF E$<>"" Schleife verlassen (EXIT), wenn 
(IF) E$ kein Leerstring ist 


210 END LOOP Schleifenende markieren 


Wertzuweisung UHR=TI-UHR vornehmen 


Abgelaufene Zeit UHR/100 in Sekunden ausgeben 





Codierung zu Programm ZEITSTOP-SIMON: 


163 REM ======FREOGERAMM ZEITSTOF-5IMÖH 
118 REM <SIMÖON’S BASIC, LOOF-ENDLOGF 
120 FREINT "COMPUTER STOPFT DIE ZEIT." 
130 : 

140 FREINT "ZEIT LRAEUFT AB TASTENDELCH :" 
156 GET Ef: IF E#="" THEN 158 

lcd LET UHR=TI : FRINT ".... LAEUFT „.." 
170 FRINT "ZEIT STOFFT BEI TASTEHDRUCH:" 
za LOOP 

Sa GET E# 

zug EXIT IP ERo"N 

219 END LOOP 

220 LET UHR=TI-LHR 

230 PRINT "ZEIT: ";UHR-1AG; "SEKUNDEN. 

248 FEINT "ENDE." : END 


m m 


3.10.4 Unterprogramm mittels EXEC-PROC-END PROC 


In Abschnitt 3.1.4 haben wir anhand des Programmes DEMO-UPRO1 
die Unterprogrammtechnk mit BASIC 2.0 erklärt. 

Das folgende Programm DEMP-UPRO1-SIMON unterscheidet sich von 
DEMO-UPROI nur in der BASIC-Codierung, nicht aber im Programm- 
lauf. 


Unterprogramm in BASIC 2.0: Unterprogramm in SIMON's BASIC: 


Aufruf: 140 GOSUB 1000 140 EXEC ERHOEHEN 
Codierung: 1000 REM ... 1000 PROC ERHOEHEN 
1010 ... 1010 ... 


1020 RETURN 1020 END PROC 
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In SIMON's BASIC wird das Unterprogramm benannt (hier der Un- 
terprogrammname ERHOEHEN), um es mit diesem Namen dann mehr- 
mals aufzurufen (hier: 140 EXEC ERHOEHEN, 180 EXEC ERHOEHEN). 


Codierung zu Programm DEMO-UPRO1-SIMON: 


124 REM ======PROGEANMM DEMO-UPFROI1-SIMÖN 

121 REM £<SIMON’S EASIC. EREC-FRÜL-END FROC. 

1a REM ABLAUF WIE FROGFAMM DEMO-LPRO1) 

142 

11 PRINT "EIN UNTERPROGERMM ZUEIMAL AUFRUFEN." 

128 INPUT "WERT WOH S 2-"3 8 

1:0 REM KAXERSTER UINTERPROGRAMM-AUFRUF MIT $33sssksskisiiktik 
140 LET FAR=& : Z&EC ERHÜEHEN 


170 LET K=PFR : PEINT "= UM 18 ERHOEHT ->": & 

1E60 INPUT "WERT YÜH Yo -" V 

ira FEM &4#ZWEITER UNTERFEOGREAMM-AUFEUF&MIT FIRE EEE 
128 LET FAR=Y : EHEC EFHÖEHEH 

124 LET Y=FAR : FRINT "T UM 12 EEHDEHT ->": " 

za FRINT "ENDE." : END 

2jE 

211: 


.... 
-* * 


FEM ###UÜNTERFRÜGEAMM "ERHDEHEN EEE 
nad PROC ERHDEHEH 
1918 LET FAR = FAR + 10 


1028 END FROC 


T 
u 


Das Progammbeispiel DEMO-UPRO1-SIMON zeigt, daß auch die Spra- 
che SIMON's BASIC keine Parameterübergabe beim Unterprogramm- 
aufruf erlaubt. Gleichwohl gestatten die Anweisungen LOCAL und 
GLOBAL, Variablen zu lokalisieren. 


Im Zusammenhang mit Unterprogrammen wird häufig die Anweisung 
CALL verwendet, die mit der Sprunganweisung GOTO vergleichbar 
ist: 


300 IF A$="JA" THEN GOTO 500 300 IF A$="JA" THEN CALL SUCHEN 


500 ... 500 PROC SUCHEN 
510 ... 510 ... 
520 END 520 END 


CALL SUCHEN bezweckt also einen Sprung zu Zeile 500, die nicht 
direkt mit der Zeilennummer genannt wird, sondern mit der sym- 
bolischen Sprungadresse SUCHEN als sogenanntem '"Label'. 

Dies erhöht die Lesbarkeit eines Programmes. 
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3.10.5 Ausgabeformatierung mittels USE 


Die meisten höheren Programmiersprachen haben die PRINT USING- 
Anweisung zur Formatierung der Druckausgabe. In SIMON's BASIC 
heißt die entsprechende Anweisung USE. 

Wie das Programmbeispiel PRINTUSING-SIMON zeigt, wird der nu- 
merische Wert einem Formatstring entsprechend formgerecht aus- 
gegeben. Der Formatstring kann als Konstante (z.B. "#HHHH.HH") 
oder als Variable (z.B. F$) in der USE-Anweisung genannt wer- 
den. Das Zeichen "#" reserviert dabei genau eine Stelle in der 
Druckausgabe. 

Die zu formatierenden numerischen Werte müssen in USE in je- 
dem Fall als Strings umgewandelt angegeben werden. 


Ausführung zu Programm PRINTUSING-SIMON: 
RUN /RET/ /RET/ für RETURN 


DEMONSTRATION ZUR AUSGABEFORMATIERUNG: 
AUSGABE UNFORMATIERT MIT PRINT: 


123.456 
71788.9 
FORMATIERT MIT USE (4.2 STELLEN): 
123.45 
7188.9 
FORMATIERT MIT USE (20.3 STELLEN): 
123.456 
7788.9 
READY. 


Diese Ausführung zeigt, daß USE Dezimalstellen abschneidet, 
nicht aber rundet (aus 123.456 wird 123.45). 


Codierung zu Programm PRINTUSING-SIMON: 


{50 REM ======PROGRAMM PRINTUSING-SIMON 
118 PRINT "DEMONSTRATION ZUR AUSGABEFORMATIERUNG:" 
120 LET Fi=123.456: LET T2=7788.9 


148 LET Zi$=STR$CZ1>: LET 2Z2$=STR$CZ2) 

158 PRINT "AUSGABE UNFORMATIERT MIT FRINT:" 

168 FEINT 21 : FEINT Z2 : FEINT 

178 FREINT "FORMATIERT MIT USE «4.2 STELLEN! 

158 LEEFRRHRC HH" ZI SPRINT: 8, "HH", 324 

138 FRINT:PRINT "FORMATIERT MIT USE 220.3 STELLENS:" 
208 LET F$="HHBHHBHRHBHHHBHHIHIIHHE. HH" 

218 use F#,Zi#: FRINT 

z20 USE FF.22H 

238 END 
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3.11 Musikverarbeitung mit SIMON’s BASIC 


Mit dem SID (Sound Interface Device) verfügt der 
über einen anspruchsvollen Musik-Synthesizer. 
Leider ist der SID in BASIC 2.0 nicht gerade einfach zu pro- 
grammieren, da überwiegend in der maschinennahen Ebene mit 
POKE-Anweisungen gearbeitet werden muß. 

SIMON's BASIC verfügt über spezielle Anweisungen zur Musik- 
programmierung, die das Schreiben von Musikstücken sowie das 
Imitieren von Musikinstrumenten stark vereinfachen. 


Commodore 64 


Am Beispiel des Liedes "Der Mond ist aufgegangen" wollen wir 
den prinzipiellen Auf ba u eines Musikpro- 
grammes darstellen und die hierfür erforderlichen Anweisungen 
in SIMON's BASIC erklären. 


3.11.1 Ausführungen eines Musikprogramms 
Betrachten wir zunächst die beiden Ausführungen zum Programm 
LIED-MOND-SIMON: 

Im 1. Punkt legen wir durch Tastatureingabe mit den Parametern 
ATTACK, DECAY, SUSTAIN, RELEASE die Hüllkur ve fest, 
welche die Charakteristik eines Instrumentes oder einer Stimme 
prägt. In der 1. Ausführung (links) legen wir mit 10,0,8,8 ei- 


nen der Violine ähnlichen Tonfall 


fest; in der 


imitieren wir mit 4,2,12,4 eine Trompete. 
Das Tempo wird mit 12 angegeben. 


Die anschließenden Schritte 2-5 übernimmt das Programm selbst: 
maximale Lautstärkenwert 
am Fernsehgerät können wir die Lautstärke va- 


2. Mit 15 wird der 
den Reglerknopf 
riieren). 


Zwei Ausführungen zu Programm LIED-MOND-SIMON: 


DER MOND IST AUFGEGANGEN. 


1. HUELLENKURVEN-PARAMETER: 
ATTACK (0-15)? 10 /RET/ 
DECAY (0-15)? O /RET/ 
SUSTAIN (0-15)? 8 /RET/ 
RELEASE (0-15)? 8 /RET/ 
TEMPO (0-255)? 12 /RET/ 


2. LAUTSTAERKE FESTGELEGT MIT VOL: 


VOL 15 = MAXIMAL 


3. KLANGFARBE FESTGELEGT MIT WAVE: 


VOLL, SAEGEZAHN-WELLENFORM 

4. NOTENSTRINGS ZUGEWIESEN 

5. LIED SPIELEN (TASTE DRUECKEN) 

... Lied wird gespielt, Huell- 
kurve imitiert Violine ... 


ENDE DES LIEDES. 
READY. 


DER MOND IST AUFGEGANGEN. 


l. HUELLENKURVEN-PARAMETER: 
ATTACK (0-15)? 4 /RET/ 
DECAY (0-15)? 2 /RET/ 
SUSTAIN (0-15)? 12 /RET/ 
RELEASE (0-15)? 4 /RET/ 
TEMPO (0-255)? 12 /RET/ 
2. LAUTSTAERKE FESTGELEGT MIT VOL: 
VOL 15 = MAXIMAL 
3. KLANGFARBE FESTGELEGT MIT WAVE: 
VOLL, SAEGEZAHN-WELLENFORM 
4. NOTENSTRINGS ZUGEWIESEN 
5. LIED SPIELEN (TASTE DRUECKEN) 
... Lied wird gespielt, Huell- 
kurve imitiert Trompete ... 


ENDE DES LIEDES. 
READY. 


2. Ausführung 


vorgegeben (über 
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3. Es wird ein voller Klang angenommen (auf die Wellenform ge- 
hen wir später ein). 

4. Die Noten des Liedes "Der Mond ist aufgegangen" werden in 
Strings zugewiesen. 

5. Das Progamm wartet und beginnt nach Drücken einer Taste mit 
dem Spielen von "Der Mond ist aufgegangen". 





Hüllkurven charakterisieren einen Ton mit vier Parametern 


Zur oberen Hüllkurve der Trompete: 

Nach dem Anspielen einer Note in der durch ATTACK=4 relativ 
schnell angegebenen Geschwindigkeit nimmt die Lautstärke bis 
zum Maximalwert VOL=15 zu. Da DECAY=2 ist, fällt diese Laut- 
stärke rasch zur mitleren Lautstärke SUSTAIN=12 ab, um dann 
endlich in der Geschwindigkeit RELEASE=4 zur Lautstärke 0 zu- 
rückzugehen, d.h. zu verstummen. 

Mit der obigen grafischen Darstellung von Hüllkurven lassen 
sich typische Instrumente sowie Stimmen gut veranschaulichen. 
Dem Ausprobieren von typischen Klangbildern durch Programmaus- 
führungen sind keine Grenzen gesetzt. 


3.11.2 Eintippen der Noten eines bestimmten Liedes 


Die BASIC-Codierung zu Programm LIED-MOND-SIMON ist in fünf 
Punkte gegliedert. Diese Gliederung gilt für jedes Lied glei- 
chermaßen. Wollen wir ein anderes Lied programmieren, so sind 
demzufolge nur die Anweisungen unter Gliederungspunkt 4. aus- 
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zutauschen, d.h. neu einzutippen. Da dieses Eintippen nicht so 
ganz einfach ist, wollen wir es genau erklären: 


Der Punkt 4. umfaßt im Beispiel die Zeilen 280 - 320. Zunächst 
werden die 4 Notenstrings den Variablen M1$, M2$, M3$ und M4$ 
zugewiesen. Diese werden in Zeile 320 zum Gesamtnotenstring M$ 
addiert. 

Die Notenstrings sind in '"Tastenschrift' wiedergegeben, da die 
normalerweise am Bildschirm erscheinenden Grafikzeichen kaum 
lesbar sind. In 'Tastenschrift' bedeuten: 


(C) Tasten /SHIFT/ und /CLR-HOME/ gleichzeitig gedrückt 
(am Bildschirm erscheint das "Herz" als Grafikzeichen). 
(F5) Funktionstaste F5 einmal kurz gedrückt: die vorher an- 
gegebene Note (z.B. C3) wird als 1/4-Note, d.h. als No- 
te der Länge 1/4 gespielt. 

- (F7) Funktionstaste /F7/ einmal gedrückt: die vorangehende 
Note wird als 1/2-Note -also doppelt so lange- ge- 
spielt. 

- C3 Erst "C" tippen und dann "3": Die Note C der Tonleiter 
wird gespielt, und zwar das C in der 3. Oktave. 

- D3 Erst "D" tippen und dann "3": Die um 1 höhere Note D 

ebenfalls in der 3. Oktave wird gespielt. 


- 1 Anfang eines Notenstrings: Nach dem (C) wird die I als 
die 1. Stimme festgelegt (wir können die Stimmen 1 - 3 
festlegen). 

-G Ende eines Notenstrings: Nach dem (C) tippen wir stets 


ein G ein. 


Codierung zu Programm LIED-MOND-SIMON: 


100 REM ======PROGRAMM LIED-MOND-SIMON 
110 PRINT "DER MOND IST AUFGEGANGEN." : PRINT 
120 ; 


130 PRINT "1. HUELLKURVEN-PARAMETER: " 

140 INPUT "ATTACK (0-15)"; ATTACK 

150 INPUT "DECAY (0-15)"; DECAY 

169 INPUT "SUSTAIN(O-15)"; SUSTAIN 

170 INPUT "RELEASE(0-15)"; RELEASE 

190 INPUT "TEMPO (0-255)"; TEMPO 

200 PRINT "2. LAUTSTAERKE FESTGELEGT MIT VOL:" 

210 PRINT "VOL 15 = MAXIMAL" 

211 VOL 15 

220 PRINT "3. KLANGFARBE FESTGELEGT MIT WAVE:" 

230 PRINT "VOLL, SAEGEZAHN-WELLENFORM" 

231 WAVE 1,00100000 

260 ENVELOPE 1,ATTACK,DECAY,SUSTAIN, RELEASE 

270 PRINT "4. NOTENSTRINGS ZUGEWIESEN" 

280 LET M1$="(C)1C3(F5)D3(F5)C3(F5)F3(F5)E3C(F5)D3(F7)CICF5)CC)C" 
290 LET M2$="(C)1E3(F5)E3CF5)E3(F5)A3C(F5)G3(F5)F3C(F7)EICF5)CC)G" 
300 LET M3$="(C)1E3(F5)E3(F5)E3(F5)F3(F5)E3(F5)D3(F7)D3CF5)CC)G" 
310 LET MA$="(C)1E3(F5)E3(F5S)E3(F5)F3C(F5)E3CF5)D3(F5)D3(F5)C3(F5)(C)C" 
320 LET M$ = M1$+M2$+M3$+M1$+M2$+M4$ 

330 PRINT "5. LIED SPIELEN (TASTE DRUECKEN):" 

340 GET E$: IF E$="" THEN 340 

350 MUSIC TEMPO,M$ 

360 PLAYI1 

370 PRINT:PRINT "ENDE DES LIEDES." : END 
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Ein Lied kann entweder aus einem Notenstring bestehen oder aus 
mehreren Teilstrings, die dann zu einem Gesamtstring addiert 
werden. In unserem Beispielprogramm liegt eine Stringaddition 
vor, da die Teilstrings M1$ und M2$ zweimal im Lied vorkommen: 


Der Mond ist aufgegangen, Notenstring M1$ 
die goldnen Sternlein prangen Notenstring M2$ 
am Himmel hell und klar. Notenstring M3$ 
Der Wald steht schwarz und schweiget, Notenstring M1$ 
und aus den Wiesen steiget Notenstring M2$ 
der weiße Nebel wunderbar. Notenstring M4$ 


Die Stringaddition 

320 LET M$ = M1$+M2$+M3$+M1$+M2$+M4$ 
verknüpft die sechs Zeilen des Liedes zu einer Notenfolge, die 
dann genau einer Strophe entspricht. 





Eingaben innerhalb eines Notenstrings 


Die BASIC-Codierung zum Programm LIED-MOND-SIMON sieht nur das 
Abspielen e i n e r Liedstrophe vor. 

Sollen mehrere Strophen gespielt werden, so können wir dies 
z.B. durch folgende Erweiterung vornehmen: 


360 PLAY 1 Liedstrophe wird gespielt. 

361 VOL 0 Lautstärke wird abgestellt (stumm). 
362 FOR ZEIT=1 TO 500: NEXT ZEIT Pause zwischen Strophen. 
363 VOL 15 Lautstärke wieder anstellen. 

363 GOTO 360 Endlosschleife. 


Das Programm hört jetzt erst dann auf, wenn wir die Programm- 
ausführung durch gleichzeitiges Drücken der Tasten /RUN-STOP/ 
und /RESTORE/ abbrechen. 
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3.11.3 Anweisungen zum Programmieren eines Liedes 


Die Programmiersprache SIMON's BASIC schreibt die Anweisungs- 


folge 
VOL Lautstärke 
WAVE Klangfarbe bzw. Sound 
ENVELOPE Form des Tones (Instrument, Stimme) 
MUSIC Noten 
PLAY Musikwiedergabe 


mit der entsprechenden Angabe von Parametern zum Programmieren 
eines Liedes vor. 

Zur Erklärung des Formates dieser Anweisungen beziehen wir uns 
wieder auf das Beispielprogramm LIED-MOND-SIMON. 


Einstellen der Lautstärke mittels VOL: 
Die Anweisung 
211 VOL 15 
stellt die Lautstärke auf den Maximalwert 15. 
Möglich sind Parameter von 0 (Abstellen der Tongeneratoren) 
bis 15 (größte Lautstärke). 


Festlegen der Wellenform mittels WAVE: 
Die Anweisung 
231 WAVE 1,00100000 
aktiviert für die Stimme 1 (1 vor dem Komma) durch Setzen von 
Bit 5 die Sägezahl-Wellenform, die einen vollen Klang ergibt. 


... WAVE S,bbbbbbbb (b für Bitposition) 
[I si 0: Gate-Bit (nicht notwendig) 

Bit 1: Synchronisation 

Bit 2: Ringmodulation 

Bit 3: Testbit (nicht setzen) 

Bit 4: Dreieck-Wellenform ('dünn', 
wenig Obertöne) 

Bit 5: Sägezahl-Wellenform ('voll', 


harmonische Obertöne) 
Bit 6: Rechteck-Wellenform ('kantig') 
Bit 7: Rauschgenerator ein. 
Stimme S (1 oder 2 oder 3) 


Festlegen der Hüllkurve mittels ENVELOPE: 
Die ENVELOPE-Anweisung hat stets die fünf Parameter 'Stimme', 
'Attack', 'Decay', 'Sustain' und "'Release'. 
In unserem Beispielprogramm werden diese Werte variabel als 
260 ENVELOPE 1,ATTACK,DECAY,SUSTAIN , RELEASE 
vorgegeben. 
Ebenso ist die Eingabe mit konstanten Werten wie z.B. 
260 ENVELOPE 1,2,0,0,4,7 
möglich. 
Für jede der Stimmen 1, 2 und 3 kann die Hüllkurve getrennt 
vorgegeben werden. 
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Festlegen der zu spielenden Noten mittels MUSIC: 
Die Anweisung 
350 MUSIC TEMPO,M$ 
spielt die im Gesamtnotenstring enthaltenen Noten mit einer 
Tondauer, wie sie in der Variablen TEMPO abgelegt ist. 
Die Anweisung 
350 MUSIC 12,L$ 
nennt eine konstante Tondauer und berücksichtigt die im String 
L$ gespeicherten Noten. 


Spielen des Musikstückes mittels PLAY: 
Die Anweisung 
360 PLAY 1 
spielt das durch die Anweisungen VOL, WAVE, ENVELOPE und MUSIC 
festgelegte Musikstück ab. PLAY 0 setzt die Musik aus. 


Das Programm LIED-MOND-SIMON bietet uns ein Anweisungsgerüst, 
das sich durch Abändern der Zeilen 280-320 zur Programmierung 
beliebiger Lieder eignet. 

Als Anregung dazu das Lied "The house of the Rising Sun", in 
das über die ersten acht Takte die Noten für die Notenstrings 
bereits in 'Tastenschrift' eingetragen sind: 


NM MNGENB MO DB mM MEEN E 








il been the vuin EREFIFR) or J = ft 


2. If I had listened to what my mother said, I'd have been 


at home today. But I was young and foolish, o God, let a d = +5 
rambler lead me astray. 
3. Go tell my baby sister, never do like I have done, but Pl _ r3 


shun that house in New Orleans, they call the Rising Sun, 


4, I'm goin' back to New Orleans, my race is almost run, 
I'm goin'! back to spend my life beneath the Rising Sun. 


Der Notenstring M1$ könnte somit wie folgt lauten: 
LET M1$="(C)1A2(F5S)A2(F7)B2(F5S)C3(FT)E3(FS)D3(F7)A2(F5S)(C)G" 
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Alle in diesem Buch dargestellten Programme sind auf einer 
5.25"-Diskette gespeichert, die unter DOS 2.x auf Disketten- 
Laufwerken wie VC 1541 und CBM 4040 ausgeführt werden können. 
Diese Diskette kann vom Verlag über die dem Buch beiliegende 
Anforderungskarte bestellt werden. 

Das nachfolgende Inhaltsverzeichnis (Directory) zeigt die Na- 
men der 78 BASIC-Programme und 3 Dateien: 


Sg LEOUETSER [04 "0 6 02H) i "ASCII-TESTI" PRG 
z HELLO" FRG & "DEZIMALBINRERI" PRG 
1 WERBEBLCHI " FRG & "BINRERDEZIMALL" PR 
1 "BREISSENKUNGI " FRG & "HEXDEZIMALL" FRG 
2 "BPRETSSENKLNGZ" PRG 3 "TEZIMALHERT" PRO 
= "KALKULRTIOHNL" FRG 2 "DTEZIMALRBINRER2" PRü 
> "SEONTOZMEISEITIG" FRG & "DEZIMALRBINRERZ3" PRO 
ze "SEÜNTOEINSEITIGI" PRG 3 "MDEZIMALRBINAER4" PRO 
2 "MREIFRELLEIL" PR Pr "PEEKLESENI " PRü 
Re HASSTL" PRG Zi "PÜRESCHREIBENI" PRG 
a "KAPITALI" FRÜG 2 "LAGERREGAL 1" FRG 
z "EBPITALF" ERG 3 OERBELDRILL1" FR& 
< "ZUFALL" PRü 4 "ARSATZTRBELLEI" PRO 
1 "RENCHMARKE-TEST1" FRG 4 "SUCHBINRERL" PRG 
“= "ERHRTENBUCHL" FRG 4 "SORTDRATENI " PRG 
Ba "RATENSFRRFETRAEBELLE" PR Re "SORTZEIGERI'" FRö 
ze "MEMO-UPPRÜ1L '" PR& 3 "SORTDATENZ" FR 
ze "DEMNO-FUNKTIONI " FRG Re "MISCHORTENI " FR 
4 "MENUEL FRü & "GRUFPFDRTENI " PRÜ 
4 "STANDARDI'" PR 13 "TELEPHON-SEOT" FRG 
1 "BOOLERNI" FRü 13 "TELEPHON-SEDOZ2" PRG 
1 "ROOLERNE" FRÜ 4 "ART-DIFESCHREIB1" FR 
ze "BOOLERNZ" FRÜü 4 "ART-DIRLESI" PRG 
+ "TERTEA" PrRG 11 "ART-DIRVYERWURLTI" PRO 
a "TERTL" FRG 4 "BALKENDIRGRAMML" PRG 
3 "TEXTE" FR Pl "GERADEI" PRG 
1 "TERTE" FR& 3 "LINIEI" PRü 
1 "TEXTE" FRG 3 "BEMEGUNGI " FRö 
ze "TERTS" FRü Bu) "BEFEHLSZEILEL" PR& 
2 "TEXTE" FRG 3 "HIRESLINIE-SIMON" PRG 
1 "TEXTT" FRü "HIRESEURFVYE-SIMNÖN" PRO 
1 "NRATUMINTI" PR S "DEMO-SFPRITEL" PRÜ& 
4 "ETIEETTENI" FRü Pe "SKONTÜZMEI-SIMON" PRO 
a "TORKER1'" PRG 3 "ERFITRLZ-SIMÖN" PR 
e\ "WERSCHLUESSELUNG" PRü & "ZEITSTOP-SIMÖN" FR 
2 "WORTSFIELL" PRÜ 3 "TEMO-UFRÜI1-SIMÖON" PRG 
2 "TURSORFPOSITION" PRO & "FRINTUSING-SIMON" FRG 
2 "DEMÜO-PRINTI" FR 1 "LIED-MÖND-SIMÖON" PRO 
pe "FUELLSTRINGL" FR 1 "TELDRTEI" SEQ 
1 "BUNDENZAHL A" FR & "ARTIKELDRTEI" FEL 
3 "EONMMERZEAHL 1" FR 4 "DIREKTDATEI" FEL 
1 "CHRF-TESTL" FRG 39434 ELÜCKS FREE. 


Programmausführung auf Commodore-Computerserien 2/3/4/8000: 
Durch Eingabe von POKE40,1:POKE41,8:POKE8*256,0:NEW 
den Programm-Zeiger auf die Anfangsadresse 2049 stellen 
(vgl. Abschnitt 2.4.2, S. 98). 

Programmausführung auf Commodore-Computern 264 und 364: 
Programm DEMO-SPRITEI läuft nicht, da Sprites verwendet. 
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Sachwortverzeichnis 


ABS() 92 

Abweisende Schleife 111 
ADA 50 

Adresse 33 154f 

Adreßbus 70 

Adreßfeld 13 

Adreßrechnung 38 192f 
Adreßzeiger 158 

Ändern (Datei) 41 
Aktueller Parameter 121 
ALGOL 50 

Algorithmus 4] 
Algorithmischer Entwurf 30 58 
Alternativstruktur 3] 

ALU 7 

AND 126 149f 

Anlegen (Datei) 41 
Anweisungsarten 35 90f 160 
Anweisungsteil (Programm) 35 103 
Anwenderprogramm 24 55£ 
Anwenderspeicher 158 

APL 50 

Arbeitsspeicher 8 

Array 26 90 163f£ 

ASC() 88 92 128 145 
ASCII-Code 10 144f 
Assembler 48 50 156 162 
ATN() 92 

ATTACK 224 

Aufzählungstyp 28 
Ausführung (Programm) 101 
Ausgabegerät 5 
Ausgabeformatierung 222 
Auswählen (Datei) 41 
Auswahlstruktur 30 106f 217 
Automat 8 45 


B (Byte) 12 76 

BACKUP 97 

Back-Up 16 

Balkencode 7 
Balkendiagramm 199 

BASIC 28 50 75 

BASIC 4.0 97£ 187£ 
BASIC-Maschine 46 
Bedingte Verzweigung 107 
Befehlsbus 70 
Befehlskanal 86 
Befehlsstring 198 
Benchmark-Test 114 
Benutzerdefinierter Typ 28 
Benutzerspeicher 158 
Bereich 26 163f£ 
Bereitschaftszeichen 76 
Betriebsart 83 


Sachwortverzeichnis 


Betriebssystem 25 45£ 
Bewegen (Datei) 41 

Bewegung (Grafik) 202 214 
Bildschirm 199 206 208 
Binärbaum 27 

Binärzeichen 9 145£ 

Binäres Suchen 169 

BIOS 52 

Bit 9 

Bitmapping 207 

Bitmuster 9 144 
Bitparallele Aufzeichnung 12 
Bitserielle Aufzeichnung 12 
Bitweise Verarbeitung 127 149f 
Bit-Struktur 73 

Blanc 141 

Block 12 

Blockdiagramm 56f 

BOOLEAN 25 

Boolesche Variable 126f 

Bps 12 

Brainware 3 

Branchenlösung 66 

BTX-Netz 21 

Bubble Memory 6 

Bubble Sort 174 

Bus 69 

Byte 10 158 


C 50 

CALL 221 
Cartridge-Tape-Streamer 16 
CBM 8032 98 
Centronics-Schnittstelle 15 
Char 25 

Character 36 

Chip 8 68 
CHR$() 92 
CLEAR 90 
CLR-Taste 78 

CLOSE 94 181 

CMC-7-Schrift 7 

CMD 90 143 

COBOL 50 

Codasyl 44 

Codierung (Programm) 55 102 
COM 5 

Commodore-BASIC 75 
Commodore-Serien 2-8000 98 
Compiler 48 162 

CONT 90 

coS() 92 

CPU 2 7 

CP/M-Betriebssystem 52 53 
TZRSR-Taste 78 


128 145 206 


Sachwortverzeichnis 


Cursor 76 138 202 
Cursorsteuerung 139 206 


DATA 85 91 123 

Datei 23 36f 168 
Dateiverarbeitung 178f£ 
Dateiverkettung 43 
Dateiverwaltungssystem 43 64 195 
Datei-Programmpaket 65 
Datei im RAM 186 

Daten 2 22£ 

Datenbank 36 43f£ 
Datenbank-Maschine 45 
Datenbus 69 
Datenerfassung 5 17£ 
Datenfeld 13 36 186 193 
Datenflußplan 56 
Datenmanager 64 
Datenredundanz 43 
Datensammelsystem 18 
Datensatz 36 193 
Datensatz-Beschreibung 188 
Datensatz-Zeiger 189 
Datensicherung 16 
Datenstrukturen 23f£ 
Datenträger 2 

Datentypen 23 25£ 
Datentypzeichen 89 
Datentyp 'boolean' 25 
Datenverkehr 42 178 193 
Datex-Netz 21 

DCLOSE 97 

DDL 43 

DECAY 212 

DEF FN 91 

Deklaration 34 
Dezentrale Erfassung 17 
Dezimal 145 

Dialog 76 

Dialoggerät 5 
Dialogprotokoll 30 101 
Dienstprogramm 24 

DIM 90 91 163£ 

Digital Research 53 
DIRECTORY 97 

Directory (Diskette) 47 84 94 
Direkte Adressierung 192 
Direktausführung 83 
Direktmodus 83 
Direktzugriff 37 
Direktzugriff-Datei 40 188f 
Diskette 6 13 86 
Divisions-Rest-Verfahren 194 
DLOAD 97 

DML 43 

Dokumentation 59 
Dollarzeichen (Hex) 154 
Dollarzeichen (Text) 89 
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DOPEN 97 187 
Doppelpunkt : 
DOS 24 53 191 
Dreieckstausch 171 

Druckbares Zeichen 139 

Drucker 14 

Druckersteuerung 139 143 
Drucker-Spooling 21 

DS (Fehlerstatus) 97 187 

DSAVE 97 

Dual-System 9 

Dynamischer Datentyp 27 
Dynamische Dimensionierung 165 


103 110 


E (Exponent) 77 
EAN-Code 7 
EBCDI-Code 10 11 
Editor 24 
Eingabegerät 5 
Einseitige Auswahl 107 
ELAN 50 

Element (Array) 163f 
ELSE 7 217 

END 91 
Endlosschleife 211 
Entwurfsprache 30 58 
ENVELOPE 227 

EOF 42 

EPROM 73 

Ethernet 21 
EVA-Prinzip 8 102 
EXEC 220 

EXIT 219 

EXP() 93 

Externer Datenbus 70 
Externer Speicher 5 
E-13-B-Schrift 7 


Fallabfrage 110 

False 127 

Farbe 139 
Fehlerbehandlung 154 185 
Fehlerinterpretation 185 187 
Feld 163£ 

Festplatte 6 

Field 36 

File 26 36 90 178£ 

Filter 151 

Firmware 2 67f£ 

Flag 129 175 

Folgestruktur 29 

FOR 91 

Formaler Parameter 121 
Formatierte Daten 22 
Formatierung 13 85£ 
Formatierung (Ausgabe) 222 
Formatstring 222 

FORTH 50 


232 


FORTRAN 50 

FRE(0) 93 153 

Funktion 92f£ 121 
Funktionstasten 78 119 


Ganzzahl (größte) 82 153 
Gap 12 14 

General-Purpose Computer 18 
Geräteadresse 84 94 
Geschlossene Schleife 117 
Gestreute Speicherung 37 
GET 91 119 

GET# 94 

Gigabyte 71 

GLOBAL 221 

GOSUB 91 120 

GOTO 91 107 
Grafikverarbeitung 199f 
Grafik-Programmpaket 65 
Grafik-Zeichen 144 203 206 225 
Großcomputer 19 
Gruppenwechsel 42 177 
Gruppieren (Daten) 177 


Hand-Held-Computer 20 
Hardware 2 4f 
Hardsektorierung 14 
Hashing 194 

Hauptspeicher 7 9 33 157 
HEADER 97 

Hexadezimal 10 145£ 
Hex-Dez-Umwandlung 155 
Hierarchische Datenbank 44 
High Byte 160 198 
Hilfsvariable 171 

HIRES 207 

Hires-Grafik 199 
Hochauflösende Grafik 99 199 207£ 
HOME-Position 78 
Homecomputer 20 

Host Computer 45 53 
Hüllkurve 223 


IC 8 67£ 

Identifikation (ID) 87 
IEC-Bus 15 

IF-THEN 91 107 
IF-THEN-ELSE 217 
Impact-Drucker 14 

Index (Array) 164 
Indexdatei 38 

Indexloch 14 

Indirekte Adressierung 194 
Individuelle Software 62 
Indizierte Speicherung 38 
Information 9 

Information Retrieval 45 
Inhouse Netz 21 


Sachwortverzeichnis 


Initialisierung 87 
INITIALIZE 94 
INPUT 91 102 119 
INPUT# 94 181 
INST-Taste 78 
INT() 93 110 113 
Integer 25 88 
Integrierte DV 66 
INTEL 72 
Interface 15 
Interpreter 48 
ISDN-Netz 21 
Iteration 31 

I/o 69 


Jackson-Methode 59 
Joker-Zeichen 134 


Kanal (Externe Einheit) 86 
Kassette 6 12 

KB 12 

Kette 39 

Klammeraffe (SAVE) 85 104 
Klammeraffe (Sprite) 212 
Klarschrift 14 
Klarschriftbeleg 6 
Klassifizieren (Datei) 41 
Klassifizierender Begriff 194 
Kluft 12 

Komma , 140 
Kommandosteuerung 62 
Kompatibilität 19 97 
Komplementärzahl 154 
Konstante 34 88£f 

Konstante (Daten-)Satzlänge 188 
Koordinaten 208 214 

Kosten 3 

Künstliche Intelligenz 4 51 
Kurvendiagramm 210 


Label 221 

Laden 93 

LAN 21 

Laufvariable 114 
Laufwerknummer 189 
Leerdatei 189 
Leerstring 130 
LEFT$() 93 128 

LEN() 93 128 

Lesen (Datei) 37 191 
LET 91 103 

Lineares Programm 29 101£ 
LINE 207 209 

Linie 201 207 

LISP 51 

LIST 81 91 

Liste 163£ 

LOAD 84 94 


Sachwortverzeichnis 
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LOAD '$'" 94 

LOCAL 221 

Lochkarte 6 

Löschen 184 

Logging 16 
Logik-Baustein 68 
Logische Operatoren 96 126 149f 
Logische Ordnung 39 
LOGO 51 

LOG() 93 

Lokales Netz 21 
LOOP-EXIT-END LOOP 219 
Low Byte 160 198 

Lücke (Datei) 193 


Magnetband 6 12 
Magnetplatte 6 
Magnetschriftbeleg 6 
Mainframe 20 
Markierungsbeleg 6 
Maschinenorientierte Sprache 48 
Maschinenprogramm 144f 
Maske (Bit) 151 

Maske (PRINT USING) 222 
Massenspeicher 13 
Master 21 

Matrix 163f 
Matrixdrucker 15 

MB 12 

Mehrfarben-Sprite 212 
Mehrseitige Auswahl 109 
Menüsteuerung 62 178 
Menütechnik 60 122 
Menware 3 

Microsoft 53 

MID$() 93 128 
Mikrocomputer (Aufbau) 69f 
Mikroprozessor 69 
Mikrotechnologie 3 

Mips 71 

Mischen (Daten) 41 176 
Mixed Hardware 16 

MMOB 213 

MOB 99 212£ 

MOB SET 213 

Mobile Datenerfassung 18 
Modul 3 

MODULA 51 
Modularisierung 59 
Motorola 72 

MS-DOS 53 

Multi-User 20 22 
Multi-Tasking 20 22 
MUSIC 228 
Musikverarbeitung 223f 


Nanosekunde 3 

Netzwerk 21 

NEW (Formatierung) 81 94 

NEW (Programm im RAM) 91 

NEXT 91 

Nicht-abweisende Schleife 112 
NOT 126 

Notenstring 225 

Numerischer Vergleich 109 


OASIS 52 
Objektprogramm 48 
OCR-Schrift 6 


ODER 9 

Öffnen (Datei) 95 181 189 
OEM 16 

Offene Schleife 117 
Off-line 5 


Oktale Konstante 82 
ON-GOSUB 91 182 
ON-GOTO 92 110 
On-line 5 

OPEN 95 181 
Operatoren 95 96 
Optische Platte 7 
OR 126 
Orädnungsdaten 22 
Organisation (Datei) 178 
Orgware 3 


OS 24 
Overlay 61 
PAP 57 108£ 


Paralleles Interface 15 
Parameter 120 221 
PASCAL 51 

PEEK() 92 153£ 
Peripherie 4 69 
Personalcomputer 19£ 
Physisch löschen 184 
Physische Ordnung 39 
Pie-Chart 199 

PILOT 51 

Pin 15 65 

Pixel 199 

PL/1 51 

PLOT (Grafik) 209 
Pointer 173 

POKE. 92 154£ 
Portabilität 54 
Portable 20 

POS(0) 93 

POS-System 18 

PRINT 92 103 140 
PRINT# 95 181 

PRINT USING 222 
Problemanalyse 55 104 
Problemorientierte Sprache 48 
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Programm 2 35 82 
Programmablaufplan 57 
Programmausführung (Betriebsart) 83 
Programmausführung (RUN) 81 
Programmeingabe 80f 104 . 
Programmentwicklung 55f£f 104£ 
Programmgenerator 61 
Programmgliederung 103 
Programmstrukturen 25 101f 217£ 
Programmlauf 101 
Programmiersprache 48 55f£ 75 
Programmiertechnik 59 
Programmierung 58 
Programm-Speicher 158 
Prompt-Zeichen 76 

Prozedur 33 

Prozessor 73 

Pseudocode 30 49 

P-Code 49 


Quellcode 49 
Quellenprogramm 48 


RAM 10 68 82 157 

READ 92 123 

READ (Datei) 181 

Real 25 88 
Rechenzentrum 19 
Rechnende Datenbank 45 
Record 26 

RECORD# 97 189 
Redundanz (Daten) 44 
Rekursion 28 

Register 70 
Relationale Datenbank 45 
Relative Datei 189f 
RELEASE 223 

RENAME 95 

REM 92 102 

Repeat (Tasten) 156 
REPEAT-UNTIL 218 
Repetition 31 
Reservierte Worte 89 160 
RESTORE 92 123 

RETURN 76 120 

RIGHT$() 93 128 
RLOCMOB (Sprites) 214 
RND() 93 113 

ROM 2 10 68 

ROM-BASIC 75 

ROM-Modul 67 

RUN 81 92 94 

Runden 142 


Satzadresse 192 
Satzlaenge 188 
Satzzeiger 189 
SAVE 83 95 


Sachwortverzeichnis 


Scanner 7 18 

SCRATCH 95 188 

Screen Editing 63 
Scrolling 63 

sd (Diskette) 86 
Sedezimal-Ziffer 147 
Sektor 13 

Sekundäradresse 86 198 
Selektion 31 

Semikolon ; 141 
Sequential File 178f 
Sequentielle Datei 40 178£f 
Sequentieller Speicher 37 
Serielle Speicherung 37 
Serielles Interface 15 
Serielles Suchen 169 

Set 26 

SGN() 93 151 

SHIFT-Taste 78 204 
SID-Baustein 99 223 
SIMON's BASIC 75 99f£ 207£ 
Simulation (Befehl) 198 
SIN() 93 

Smal Business Computer 19 
Softsektorierung 13 
Software 2 22£ 
Software-Bausteine 32 
Software-Engineering 59 
Software-Qualitätssicherung 63 
Sortieren (Datei) 168 185 
Sortierverfahren 170f 
Sortierte Verarbeitung (Datei) 39 
Spalte (Array) 165 

SPC() 93 140 
Speicherorganisation 157f 
Speicherplatz 33 153 
Speicherprogrammierung 8 
Speicher-Baustein 68 
Spielprogramm 66 137 
Spooling 21 

Spread Sheet 63 

Sprite (MOB) 99 199 211 
Sprungadresse 107 

Spur 13 86 

SOR() 93 

ss (Diskette) 86 
Suchverfahren 168f 184 
SUSTAIN 223 
Systemprogramm 24 
System-Konfiguration 19 


Schachtelung 32 110 117 166 
Schleife 31 111£f 218£ 
Schnittstelle 15 65 
Schließen (Datei) 42 94 181 
Schreiben (Datei) 37 190 
Schreibschutz 83 
Schrittplan 105 
Schrittweise Verfeinerung 61 


Sachwortverzeichnis 


235 





ST (Statusvariable) 93 154 
Stammdaten 22 
Standardisierung 124 
Standard-Funktion 121 
Standard-Software 62 
Stand-alone-System 16 18 22 
Statischer Datentyp 27 

STEP 115 210 

Steuerprogramm 24 
Steuertasten 212 
Steuerzeichen 140 

STOP 92 

Streaming 13 16 

String 88 109 
String-Verarbeitung 128f 
String-Array 26 163 
String-Speicher (RAM) 
Struktogramm 30 57 108£ 
Strukturierte Programmierung 61 
STR$() 93 128 217 
SYS 92 156 


TAB() 93 140 
Tabellenkalkulation 63 
Tabellenverarbeitung 163£ 
Takt 71 

TAN() 93 

Tape 84 

Tastenbelegung 204 214 
Tastenschrift (Musik) 225 
Teachware 3 

Textdaten 23 79 
Textvariable 89 
Textverarbeitung 128f 
Textverarbeitung (Paket) 64 
Textvergleich 109 
Thermodrucker 15 

TI (interne Uhr) 93 219 
TI$ 93 
Tintenstrahldrucker 15 
Tonleiter 226 
Top-Down-Entwurf 60 

Track 86 

True 127 

Turn-Key-System 63 
Typenraddrucker 15 


UCSD-Betriebssystem 49 53 
Übergabe (Parameter) 120 
Überläufer (Datei) 194 
Übersetzerprogramm 24 
Unbedingte Verzweigung 107 
UND (logisch) 9 126 149 
Unechte Zählerschleife 115 
UNIX 53 

Unterbereichstyp 28 
Unterprogramm 31 119f 220 
Unterprogrammtechnik 60 
UNTIL 218 

Urbeleg 17 


USE 222 
USR() 157 
Utility 24 


VAL() 94 128 

VALIDATE 95 

Variable 34 89f 
Variablenebene 125 
Variablenliste 105 
Variablentabelle 162 
Variablen-Speicher (RAM) 158 
Vektor 26 163f 

Verbund 26 

Verdichten (Daten) 177 
Verdichten (Datei) 41 
Vereinbarung 34 89 
Vereinbarungsteil (Programm) 35 103 
Vergleichsoperatoren 96 126 
VERIFY 95 

Verkettete Datei 40 
Verkettete Speicherung 39 
Verkettungsoperator + 128 
Verschlüsselung 136 
Verzweigung 106f 
Verzweigungstechnik 126 
Videocomputer 20 

VOL (Musik) 227 
Vorbereitungsteil (Schleife) 111 
V.24-Schnittstelle 15 


Wahrheitstafel 126 

WAIT 92 

Warteschleife 119 219 

WAVE (Musik) 227 

Wechselplatte 6 

Wertzuweisung 103 
Wiederholungsstruktur 31 111f 218£ 
Wiederholungsteil (Schleife) 111 
Winchesterplatte 6 

Window (Bildschirm) 206 
Wortbreite 70 

WRITE 181 


zählerschleife 114f£ 

Zeichen 9 
Zeichenkettendaten 22 
Zeichen „ ; 193 

Zeichen % $ 89 

Zeiger 38 158 189 
Zeigersortieren 173 

Zeile (Array) 165 

zilog 72 

Zufallszahl 113 

Zugriffsart (Datei) 37 
Zugriffseinheit 13 

Zuse 3 

Zuweisungszeichen = 103 128 
Zweiseitige Auswahl 106 
Zwei-Byte-Adresse 152 157 198 
2-80 Prozessor 72 


VMIEWES 


Programmieren von Mikrocomputern 


Band 6 

Ekkehard Kaier 

BASIC-Programmierbuch 

Zu den grundlegenden Ablaufstrukturen der Datenverarbeitung 


1983. XI, 185 S. mit 46 Programmbeisp., 179 Übungsaufg. einschl. 
Lösungen und 55 Übersichtstab. 16,2 X 22,9 cm. Br. 


Folgestrukturen (lineare Abläufe), Auswahlstrukturen (Abläufe mit 
Verzweigungen) und Wiederholungsstrukturen (Abläufe mit Schleifen) 
bilden als Ablaufstrukturen die Grundlage jeder Programmierarbeit 
und deshalb auch den Schwerpunkt dieses Buches. 


Darüberhinaus zeichnet sich das Buch durch folgenden Aufbau aus: 


— vollständige Darstellung von Ablaufstrukturen und Datenstrukturen 
mit Ausnahme der Datei; 

— Beschreibung der 46 Programme nach einheitlichem 6-Punkte- 
Schema; 

— Gliederung nach Ablaufstrukturen und nach Anwendungsgebieten; 

— Orientierung an den Prinzipien der strukturierten Programmierung; 

— Problemerläuterung jeweils anhand Programmbeispiel und Info-Über- 
sicht; 

— Übungsaufgaben zu jedem Abschnitt mit kompletten Lösungen; 

— Einsetzbarkeit der Programme auf jedem BASIC-Mikrocomputer. 


VIEWS 


Anwendung von Mikrocomputern 


Band 8 

Ernst-Friedrich Reinking 

Dienstprogramme für den VC-20, Commodore 64 und Executive 

1984. Ca. 120 S. 16,2 X 22,9 cm. Br. 

Dienst- und Hilfsprogramme (auch Utilities oder Tools genannt) sind 
nicht in der Programmiersprache BASIC, sondern in Maschinensprache 
geschrieben. Da diese Sprache schwerer verständlich ist, als die soge- 
nannten „‚Hochsprachen” BASIC, Pascal etc. ist eine ausführliche und 
verständliche Dokumentation für den Anwender besonders wichtig. 
E.-F. Reinking hat in diesem Buch die wichtigsten Hilfsprogramme, 
die jedem Hobbyprogrammierer der beiden Commodore-Mikrocom- 
puter die Arbeit erleichtern, eingehend beschrieben (zeilenweise Erklä- 
rung der Befehle, Programmlisting etc.). Damit wird dem Leser nicht 
nur geholfen die einzelnen Programme zu verstehen und auf seinem 
Rechner zu implementieren, sondern es wird ihm auch ermöglicht, 
darüber hinaus die vorliegenden Programme selbst weiterzuentwickeln. 
Die Auswahl der Dienstprogramme (Utilities, Tools) stellt einen Quer- 
schnitt der am häufigsten angewendeten Routinen aus verschiedenen 
Bereichen dar: 

Auto (Zeilennumerierung) — Renumber — Merge — Trace — Single- 
Step (Listing) — Scrawling — Dump — Search — Sort — Disassembler. 
Alle angegebenen Programme sind sofort einsetzbar und lauffähig. Dem 
weniger geübten Programmierer werden damit nicht nur fertige Pro- 
gramme geliefert, sondern auch die Möglichkeit, sich anhand der prak- 
tischen Beispiele dieser in Maschinensprache geschriebenen kleinen 
Programme in komplexere Anwendungen und die Erstellung von 
eigenen Anwendungsprogrammen einzuarbeiten. 


Programmverzeichnis 


Alle in diesem Buch dargestellten Programme sind auf einer 
5,25"_Diskette gespeichert, die unter DOS 2.x auf Disketten- 
Laufwerken wie VC 1541 und CBM 4040 ausgeführt werden können. 
Diese Diskette kann vom Verlag über die dem Buch beiliegende 
Anforderungskarte bestellt werden. 

Das nachfolgende Inhaltsverzeichnis (Directory) zeigt die Na- 
men der 78 BASIC-Programme und 3 Dateien: 

u IE LHE I Lt he 1 "BRSCTI-TESTL Fri 
= 4ELLam | "DEZIMALBIHAERL" — FRG 
"WERERRLNIHL" FR "EINREFRDEZIMALL" FR 
"EREITSSENKLUHGTL" FR "HERDEZIMALL" Fri: 
za "ERETSSEHRUHNGE" Pro "DEZIMALHERT" Fri 
E "EALELLATIOHL" FrRü "DEZIMALEIHAERE" FRI 
er ZEOHTOZWMEISELTIG" FR "DEZIMALEINAERE" FR 
Pr SEM TDEIHNSEITIGI" FRÜ "DEZIMALEINAER4" Früö 
2 "DEEIFRELLEIL" FRÜ "FEEELESENE FR 
a "ASTL" FR Bo "FOHRESCHRETBEHNL" FR 
a "ERAFLTALL" FR 2 "LAGERRFEGRALL" FrRüö 
SOERBELDREILLI" Fri 
"AEZHATZTREELLEL" Fri 





SE 
Tıı 
Bea 


LE Ro Rod IR Te 


Pi 


“} "ZUFALL" Fri 
1 "BEHCHMARK-TESTI" FR "SLKTHEIHRERL" FR 
I "ESHRTEHELIUCHL" FrRü "SORTIRATEHL" FR 
a) "RRATEHSFRARFRTREELLE" FR u "SORTEEIGERL " Fri 
Ze "NERO-UPRE " FR "SORTOEATEHE" Fr 
= “DEND-FLHRTIEORTL" FRÜ Be "ISCHELRATEHL" Fri 
1 "PEHUEL" FrRü "SEUFFDATEHL" Fr 
"STAHDARDL " FR "TELEFHÖHN-SEET" FR 
"EOnLERAHL" Fri = "TELEFHÖN-SENE" FR 
"EoiLERHE" FR "AFT-DRIFACHREIEL" FR 
"Eoll.ERAHE" Frü "ART-RIFELEST" FrRö 
"TEHTE" Fr "AFRT-DIFWERMALTI" FR 
a "TESTL" Fro "ERLEEHRIAGRANMMI" FR 
"TERATE" Fri "GERADEL" FR 
"TEHTE" FR Be "LIMIEL" FR 
"TEST" Fr Me) "BEMEGUHGL" Fri 
a "TERTE FR I "BEFEHLSEZEILEL" FrRü 
"TESTE" FRÜ "HIRESLINITE-SIMOH" FR 
"TERATT" FR "HIRESERREWE-S TPM" FR 
"MATUpPLIHTi" Fri Be "DEMO-SFRITEL" Frü 
"ETIEKETTEHL" Fri "SEÜOHTOEMEI-STIPMOH" FR 
"U TOKERL" FRÜü .S "ERFITALZ-S1IMOH" FR 
ERSCHLUESSELLUFG" "ZEITSTOF-STIMNDOH" Fr 
ze NORTSrLELL" Fr a "TDEMO-UFROL-S TOR" FR 
2 OrRSOrRFOSLTIOHL" Frü "PFRIMNTUSTNG-SINOH" FrRü 
2 "REMO-PRIHTL" Frü "LIED-MÖOHR-SIMOH"  FRO 
& "FLUELLSTREIHGL" FrRü "TELDRTEI" SE 
1 "SUOHDEHZAHL I" Fri "ARTIEELIATEL" FEL. 
20 "KOPMMERZERHL I" FR "DIREEETORTEIL" FEL. 
1 ICHRE- TEST" PR 224 EBLUCHES FREE. 
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Programmausführung auf Commodore-Computerserien 2/3/4/8000: 
Durch Eingabe von POKE40,1:POKE41,8:POKE8*256,0:NEW 
den Programm-Zeiger auf die Anfangsadresse 2049 stellen 
(vgl. Abschnitt 2.4.2, S. 98). 

Programmausführung auf Commodore-Computern 264 und 364: 
Programm DEMO-SPRITEI läuft nicht, da Sprites verwendet. 


